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

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

Parent Directory Parent Directory | Revision Log Revision Log


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

  ViewVC Help
Powered by ViewVC 1.1.20