1 |
package dk.daoas.daoadresseservice; |
package dk.daoas.daoadresseservice; |
2 |
|
|
3 |
import java.io.IOException; |
import java.io.IOException; |
|
import java.io.UnsupportedEncodingException; |
|
4 |
|
|
5 |
import javax.servlet.ServletException; |
import javax.servlet.ServletException; |
6 |
import javax.servlet.annotation.WebServlet; |
import javax.servlet.annotation.WebServlet; |
8 |
import javax.servlet.http.HttpServletRequest; |
import javax.servlet.http.HttpServletRequest; |
9 |
import javax.servlet.http.HttpServletResponse; |
import javax.servlet.http.HttpServletResponse; |
10 |
|
|
11 |
|
import dk.daoas.daoadresseservice.admin.ServiceConfig; |
12 |
import dk.daoas.daoadresseservice.beans.Address; |
import dk.daoas.daoadresseservice.beans.Address; |
13 |
import dk.daoas.daoadresseservice.beans.SearchResult; |
import dk.daoas.daoadresseservice.beans.SearchResult; |
14 |
import dk.daoas.daoadresseservice.beans.SearchResult.Status; |
import dk.daoas.daoadresseservice.beans.SearchResult.Status; |
15 |
|
import dk.daoas.daoadresseservice.db.LogPersistance; |
16 |
|
|
17 |
/** |
/** |
18 |
* Servlet implementation class SearchServlet |
* Denne servlet forventer at Tomcat connector'en er konfigureret med |
19 |
|
* URIEncoding="UTF-8" |
20 |
*/ |
*/ |
21 |
@WebServlet(urlPatterns = { "/SearchServlet", "/search" }, loadOnStartup = 1) |
@WebServlet(urlPatterns = { "/SearchServlet", "/search" }, loadOnStartup = 1) |
22 |
public class SearchServlet extends HttpServlet { |
public class SearchServlet extends HttpServlet { |
23 |
|
|
24 |
|
private static final long serialVersionUID = 1L; |
25 |
|
LogPersistance logPersistance; |
26 |
|
ServiceConfig config; |
27 |
|
|
28 |
@Override |
@Override |
29 |
public void init() throws ServletException { |
public void init() throws ServletException { |
30 |
super.init(); |
super.init(); |
31 |
|
|
32 |
|
config = (ServiceConfig) this.getServletContext().getAttribute("config"); |
33 |
|
logPersistance = new LogPersistance(); |
34 |
|
|
35 |
System.out.println("SearchServlet loaded"); |
System.out.println("SearchServlet loaded"); |
36 |
} |
} |
|
|
|
|
|
|
|
private static final long serialVersionUID = 1L; |
|
|
|
|
|
String getUtf8(String str) throws UnsupportedEncodingException { |
|
|
return new String( str.getBytes("iso-8859-1"), "UTF-8"); |
|
|
} |
|
37 |
|
|
38 |
|
|
39 |
protected void doGet(HttpServletRequest request, HttpServletResponse response) throws ServletException, IOException { |
protected void doGet(HttpServletRequest request, HttpServletResponse response) throws ServletException, IOException { |
40 |
//long start1 = System.currentTimeMillis(); |
|
41 |
AdressSearch search = (AdressSearch) this.getServletContext().getAttribute("search"); |
AdressSearch search = (AdressSearch) this.getServletContext().getAttribute("search"); |
42 |
request.setCharacterEncoding("UTF-8"); |
if (search == null) { |
43 |
|
response.setContentType("text/xml; charset=UTF-8"); |
44 |
|
response.getWriter().print( generateErrorXML("Service not ready") ); |
45 |
|
return; |
46 |
|
} |
47 |
|
|
48 |
String brugerid = request.getParameter("brugerid"); |
String brugerid = request.getParameter("brugerid"); |
49 |
String postnr = request.getParameter("postnr"); |
String postnr = request.getParameter("postnr"); |
|
//String adresseStr = getUtf8( request.getParameter("adresse") ); |
|
50 |
String adresseStr = request.getParameter("adresse"); |
String adresseStr = request.getParameter("adresse"); |
51 |
|
|
52 |
|
if (postnr == null) { |
53 |
|
response.setContentType("text/xml; charset=UTF-8"); |
54 |
|
response.getWriter().print( generateErrorXML("Mangler postnr parameter") ); |
55 |
|
return; |
56 |
|
} |
57 |
|
|
58 |
|
if (adresseStr == null) { |
59 |
|
response.setContentType("text/xml; charset=UTF-8"); |
60 |
|
response.getWriter().print( generateErrorXML("Mangler adresse parameter") ); |
61 |
|
return; |
62 |
|
} |
63 |
|
if (brugerid == null) { |
64 |
|
brugerid = request.getRemoteHost(); |
65 |
|
} |
66 |
|
|
|
//long start2 = System.currentTimeMillis(); |
|
67 |
SearchResult result = search.search(postnr, adresseStr); |
SearchResult result = search.search(postnr, adresseStr); |
68 |
|
|
|
//long start3 = System.currentTimeMillis(); |
|
69 |
|
|
70 |
StringBuilder sb = new StringBuilder(); |
StringBuilder sb = new StringBuilder(); |
71 |
sb.append("<result>"); |
sb.append("<result>\n"); |
72 |
|
|
73 |
if (result.status == Status.STATUS_OK) { |
if (result.status == Status.STATUS_OK) { |
74 |
sb.append("<status>ok</status>"); |
sb.append("<status>ok</status>"); |
77 |
sb.append("<kommunekode>").append(result.address.kommunekode).append("</kommunekode>"); |
sb.append("<kommunekode>").append(result.address.kommunekode).append("</kommunekode>"); |
78 |
sb.append("<vejkode>").append(result.address.vejkode).append("</vejkode>"); |
sb.append("<vejkode>").append(result.address.vejkode).append("</vejkode>"); |
79 |
sb.append("<dbkbane>").append(result.address.dbkBane).append("</dbkbane>"); |
sb.append("<dbkbane>").append(result.address.dbkBane).append("</dbkbane>"); |
80 |
|
sb.append("\n"); |
81 |
|
|
82 |
//Extra information |
//Extra information |
83 |
|
sb.append("<vejnavn>").append(result.address.vejnavn).append("</vejnavn>"); |
84 |
sb.append("<daekning>").append(result.address.daekningsType).append("</daekning>"); |
sb.append("<daekning>").append(result.address.daekningsType).append("</daekning>"); |
85 |
sb.append("<distributor>").append(result.address.distributor).append("</distributor>"); |
sb.append("<distributor>").append(result.address.distributor).append("</distributor>"); |
86 |
if (result.address.daekningsType == DaekningsType.DAEKNING_UDVIDET) { |
if (result.address.daekningsType == DaekningsType.DAEKNING_UDVIDET) { |
89 |
Address t = result.address.extTarget; |
Address t = result.address.extTarget; |
90 |
sb.append("<extaddr>").append(t.vejnavn + " " + t.husnr + t.husnrbogstav + ", " + t.postnr).append("</extaddr>"); |
sb.append("<extaddr>").append(t.vejnavn + " " + t.husnr + t.husnrbogstav + ", " + t.postnr).append("</extaddr>"); |
91 |
} |
} |
92 |
|
|
93 |
|
sb.append("<osm>").append(result.osm).append("</osm>"); |
94 |
|
sb.append("<osmvej>").append(result.osmVej).append("</osmvej>"); |
95 |
|
|
96 |
sb.append("<google>").append(result.google).append("</google>"); |
sb.append("<google>").append(result.google).append("</google>"); |
97 |
|
sb.append("<googlevej>").append(result.googleVej).append("</googlevej>"); |
98 |
|
|
99 |
|
|
100 |
} else { |
} else { |
105 |
|
|
106 |
response.setContentType("text/xml; charset=UTF-8"); |
response.setContentType("text/xml; charset=UTF-8"); |
107 |
response.getWriter().print( sb ); |
response.getWriter().print( sb ); |
108 |
|
|
109 |
|
logPersistance.saveRequestLog(brugerid, postnr, adresseStr, result); |
110 |
|
|
111 |
|
} |
112 |
|
|
113 |
/* |
private String generateErrorXML(String msg) { |
114 |
long start4 = System.currentTimeMillis(); |
StringBuilder sb = new StringBuilder(); |
115 |
System.out.println("Servlet2:" + (start2-start1) ); |
sb.append("<result>"); |
116 |
System.out.println("Servlet3:" + (start3-start1) ); |
sb.append("<status>error</status>"); |
117 |
System.out.println("Servlet4:" + (start4-start1) ); |
sb.append("<error>").append(msg).append("</error>"); |
118 |
*/ |
sb.append("</result>"); |
119 |
|
|
120 |
|
return sb.toString(); |
121 |
|
|
122 |
} |
} |
123 |
|
|
124 |
} |
} |