/[projects]/dao/DaoAdresseService/src/main/java/dk/daoas/daoadresseservice/SearchServlet.java
ViewVC logotype

Annotation of /dao/DaoAdresseService/src/main/java/dk/daoas/daoadresseservice/SearchServlet.java

Parent Directory Parent Directory | Revision Log Revision Log


Revision 2372 - (hide annotations) (download)
Tue Feb 24 20:38:56 2015 UTC (9 years, 3 months ago) by torben
Original Path: dao/DaoAdresseService/src/dk/daoas/daoadresseservice/SearchServlet.java
File size: 3935 byte(s)
Implemented search log to db
1 torben 2274 package dk.daoas.daoadresseservice;
2    
3     import java.io.IOException;
4     import java.io.UnsupportedEncodingException;
5    
6     import javax.servlet.ServletException;
7     import javax.servlet.annotation.WebServlet;
8     import javax.servlet.http.HttpServlet;
9     import javax.servlet.http.HttpServletRequest;
10     import javax.servlet.http.HttpServletResponse;
11    
12 torben 2346 import dk.daoas.daoadresseservice.admin.ServiceConfig;
13 torben 2290 import dk.daoas.daoadresseservice.beans.Address;
14 torben 2282 import dk.daoas.daoadresseservice.beans.SearchResult;
15     import dk.daoas.daoadresseservice.beans.SearchResult.Status;
16 torben 2372 import dk.daoas.daoadresseservice.db.LogPersistance;
17 torben 2274
18     /**
19 torben 2311 * Denne servlet forventer at Tomcat connector'en er konfigureret med
20     * URIEncoding="UTF-8"
21 torben 2274 */
22 torben 2277 @WebServlet(urlPatterns = { "/SearchServlet", "/search" }, loadOnStartup = 1)
23 torben 2274 public class SearchServlet extends HttpServlet {
24 torben 2278
25 torben 2372 private static final long serialVersionUID = 1L;
26     LogPersistance logPersistance;
27 torben 2346 ServiceConfig config;
28    
29 torben 2278 @Override
30     public void init() throws ServletException {
31     super.init();
32 torben 2346
33     config = (ServiceConfig) this.getServletContext().getAttribute("config");
34 torben 2372 logPersistance = new LogPersistance();
35 torben 2346
36 torben 2278 System.out.println("SearchServlet loaded");
37     }
38 torben 2372
39 torben 2278
40 torben 2274
41     String getUtf8(String str) throws UnsupportedEncodingException {
42     return new String( str.getBytes("iso-8859-1"), "UTF-8");
43     }
44    
45    
46     protected void doGet(HttpServletRequest request, HttpServletResponse response) throws ServletException, IOException {
47 torben 2299
48 torben 2274 AdressSearch search = (AdressSearch) this.getServletContext().getAttribute("search");
49 torben 2299 if (search == null) {
50     response.setContentType("text/xml; charset=UTF-8");
51 torben 2302 response.getWriter().print(
52     "<result>" +
53 torben 2299 "<status>error</status>" +
54 torben 2302 "<error>Service not ready</error>" +
55 torben 2306 "</result>"
56 torben 2299 );
57     return;
58    
59     }
60 torben 2274
61     String brugerid = request.getParameter("brugerid");
62     String postnr = request.getParameter("postnr");
63 torben 2287 String adresseStr = request.getParameter("adresse");
64 torben 2274
65 torben 2350 SearchResult result = search.search(postnr, adresseStr);
66 torben 2274
67 torben 2288
68 torben 2274 StringBuilder sb = new StringBuilder();
69 torben 2294 sb.append("<result>\n");
70 torben 2274
71     if (result.status == Status.STATUS_OK) {
72     sb.append("<status>ok</status>");
73     sb.append("<distrikt>").append(result.address.rute).append("</distrikt>");
74     sb.append("<koreliste>").append(result.address.koreliste).append("</koreliste>");
75     sb.append("<kommunekode>").append(result.address.kommunekode).append("</kommunekode>");
76     sb.append("<vejkode>").append(result.address.vejkode).append("</vejkode>");
77     sb.append("<dbkbane>").append(result.address.dbkBane).append("</dbkbane>");
78 torben 2294 sb.append("\n");
79 torben 2274
80 torben 2276 //Extra information
81 torben 2294 sb.append("<vejnavn>").append(result.address.vejnavn).append("</vejnavn>");
82 torben 2276 sb.append("<daekning>").append(result.address.daekningsType).append("</daekning>");
83     sb.append("<distributor>").append(result.address.distributor).append("</distributor>");
84 torben 2290 if (result.address.daekningsType == DaekningsType.DAEKNING_UDVIDET) {
85     sb.append("<extafstand>").append(result.address.extAfstand).append("</extafstand>");
86    
87     Address t = result.address.extTarget;
88 torben 2291 sb.append("<extaddr>").append(t.vejnavn + " " + t.husnr + t.husnrbogstav + ", " + t.postnr).append("</extaddr>");
89 torben 2290 }
90 torben 2359
91 torben 2301 sb.append("<osm>").append(result.osm).append("</osm>");
92 torben 2359 sb.append("<osmvej>").append(result.osmVej).append("</osmvej>");
93    
94 torben 2292 sb.append("<google>").append(result.google).append("</google>");
95 torben 2359 sb.append("<googlevej>").append(result.googleVej).append("</googlevej>");
96 torben 2276
97 torben 2292
98 torben 2274 } else {
99     sb.append("<status>error</status>");
100     sb.append("<error>").append( result.status ).append("</error>");
101     }
102     sb.append("</result>");
103    
104     response.setContentType("text/xml; charset=UTF-8");
105     response.getWriter().print( sb );
106    
107 torben 2372 logPersistance.saveRequestLog(brugerid, postnr, adresseStr, result);
108    
109 torben 2274 }
110    
111     }

  ViewVC Help
Powered by ViewVC 1.1.20