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

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

Parent Directory Parent Directory | Revision Log Revision Log


Revision 2372 - (show annotations) (download)
Tue Feb 24 20:38:56 2015 UTC (9 years, 2 months ago) by torben
File size: 3935 byte(s)
Implemented search log to db
1 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 import dk.daoas.daoadresseservice.admin.ServiceConfig;
13 import dk.daoas.daoadresseservice.beans.Address;
14 import dk.daoas.daoadresseservice.beans.SearchResult;
15 import dk.daoas.daoadresseservice.beans.SearchResult.Status;
16 import dk.daoas.daoadresseservice.db.LogPersistance;
17
18 /**
19 * Denne servlet forventer at Tomcat connector'en er konfigureret med
20 * URIEncoding="UTF-8"
21 */
22 @WebServlet(urlPatterns = { "/SearchServlet", "/search" }, loadOnStartup = 1)
23 public class SearchServlet extends HttpServlet {
24
25 private static final long serialVersionUID = 1L;
26 LogPersistance logPersistance;
27 ServiceConfig config;
28
29 @Override
30 public void init() throws ServletException {
31 super.init();
32
33 config = (ServiceConfig) this.getServletContext().getAttribute("config");
34 logPersistance = new LogPersistance();
35
36 System.out.println("SearchServlet loaded");
37 }
38
39
40
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
48 AdressSearch search = (AdressSearch) this.getServletContext().getAttribute("search");
49 if (search == null) {
50 response.setContentType("text/xml; charset=UTF-8");
51 response.getWriter().print(
52 "<result>" +
53 "<status>error</status>" +
54 "<error>Service not ready</error>" +
55 "</result>"
56 );
57 return;
58
59 }
60
61 String brugerid = request.getParameter("brugerid");
62 String postnr = request.getParameter("postnr");
63 String adresseStr = request.getParameter("adresse");
64
65 SearchResult result = search.search(postnr, adresseStr);
66
67
68 StringBuilder sb = new StringBuilder();
69 sb.append("<result>\n");
70
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 sb.append("\n");
79
80 //Extra information
81 sb.append("<vejnavn>").append(result.address.vejnavn).append("</vejnavn>");
82 sb.append("<daekning>").append(result.address.daekningsType).append("</daekning>");
83 sb.append("<distributor>").append(result.address.distributor).append("</distributor>");
84 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 sb.append("<extaddr>").append(t.vejnavn + " " + t.husnr + t.husnrbogstav + ", " + t.postnr).append("</extaddr>");
89 }
90
91 sb.append("<osm>").append(result.osm).append("</osm>");
92 sb.append("<osmvej>").append(result.osmVej).append("</osmvej>");
93
94 sb.append("<google>").append(result.google).append("</google>");
95 sb.append("<googlevej>").append(result.googleVej).append("</googlevej>");
96
97
98 } 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 logPersistance.saveRequestLog(brugerid, postnr, adresseStr, result);
108
109 }
110
111 }

  ViewVC Help
Powered by ViewVC 1.1.20