--- dao/DaoAdresseService/src/dk/daoas/daoadresseservice/SearchServlet.java 2015/02/15 11:55:20 2299
+++ dao/DaoAdresseService/src/main/java/dk/daoas/daoadresseservice/SearchServlet.java 2015/05/13 09:36:42 2545
@@ -1,7 +1,6 @@
package dk.daoas.daoadresseservice;
import java.io.IOException;
-import java.io.UnsupportedEncodingException;
import javax.servlet.ServletException;
import javax.servlet.annotation.WebServlet;
@@ -9,47 +8,89 @@
import javax.servlet.http.HttpServletRequest;
import javax.servlet.http.HttpServletResponse;
+import org.apache.commons.lang3.StringUtils;
+
import dk.daoas.daoadresseservice.beans.Address;
import dk.daoas.daoadresseservice.beans.SearchResult;
import dk.daoas.daoadresseservice.beans.SearchResult.Status;
+import dk.daoas.daoadresseservice.db.LogPersistance;
/**
- * Servlet implementation class SearchServlet
+ * Denne servlet forventer at Tomcat connector'en er konfigureret med
+ * URIEncoding="UTF-8"
*/
@WebServlet(urlPatterns = { "/SearchServlet", "/search" }, loadOnStartup = 1)
public class SearchServlet extends HttpServlet {
+ private static final long serialVersionUID = 1L;
+
+
+ private transient LogPersistance logPersistance;
+ //transient ServiceConfig config;
+
@Override
public void init() throws ServletException {
super.init();
+
+ //config = (ServiceConfig) this.getServletContext().getAttribute("config");
+ logPersistance = new LogPersistance();
+
System.out.println("SearchServlet loaded");
}
-
- private static final long serialVersionUID = 1L;
-
- String getUtf8(String str) throws UnsupportedEncodingException {
- return new String( str.getBytes("iso-8859-1"), "UTF-8");
+ @Override
+ public void destroy() {
+ super.destroy();
+
+ if (logPersistance != null) {
+ logPersistance.shutdown();
+ }
+ System.out.println("SearchServlet destroyed");
}
-
+
+
+
+
+
protected void doGet(HttpServletRequest request, HttpServletResponse response) throws ServletException, IOException {
- AdressSearch search = (AdressSearch) this.getServletContext().getAttribute("search");
+ AddressSearch search = (AddressSearch) this.getServletContext().getAttribute("search");
if (search == null) {
response.setContentType("text/xml; charset=UTF-8");
- response.getWriter().print(
- "error" +
- "Service not ready"
- );
- return;
-
+ response.getWriter().print( generateErrorXML("Service not ready") );
+ return;
}
String brugerid = request.getParameter("brugerid");
String postnr = request.getParameter("postnr");
- //String adresseStr = getUtf8( request.getParameter("adresse") );
String adresseStr = request.getParameter("adresse");
+ String omdeling = request.getParameter("omdeling");
+
+ if (postnr == null) {
+ response.setContentType("text/xml; charset=UTF-8");
+ response.getWriter().print( generateErrorXML("Mangler postnr parameter") );
+ return;
+ }
+
+ if (adresseStr == null) {
+ response.setContentType("text/xml; charset=UTF-8");
+ response.getWriter().print( generateErrorXML("Mangler adresse parameter") );
+ return;
+ }
+ if (brugerid == null) {
+ brugerid = request.getRemoteHost();
+ }
+
+ if (omdeling == null || omdeling.equals("") ) {
+ omdeling = "H";
+ }
+
+ if ( omdeling.equals("H") == false && omdeling.equals("S") == false ) {
+ response.setContentType("text/xml; charset=UTF-8");
+ response.getWriter().print( generateErrorXML("Ugyldig omdelingsdag - Kun H og S er gyldig") );
+ return;
+ }
SearchResult result = search.search(postnr, adresseStr);
@@ -59,35 +100,85 @@
if (result.status == Status.STATUS_OK) {
sb.append("ok");
- sb.append("").append(result.address.rute).append("");
- sb.append("").append(result.address.koreliste).append("");
- sb.append("").append(result.address.kommunekode).append("");
- sb.append("").append(result.address.vejkode).append("");
- sb.append("").append(result.address.dbkBane).append("");
- sb.append("\n");
-
- //Extra information
- sb.append("").append(result.address.vejnavn).append("");
- sb.append("").append(result.address.daekningsType).append("");
- sb.append("").append(result.address.distributor).append("");
- if (result.address.daekningsType == DaekningsType.DAEKNING_UDVIDET) {
- sb.append("").append(result.address.extAfstand).append("");
-
- Address t = result.address.extTarget;
- sb.append("").append(t.vejnavn + " " + t.husnr + t.husnrbogstav + ", " + t.postnr).append("");
- }
- sb.append("").append(result.google).append("");
-
-
} else {
sb.append("error");
- sb.append("").append( result.status ).append("");
}
+
+ String rute = StringUtils.defaultString(result.address.rute); //Sikre at der ikke sendes "null" tilbage
+ String koreliste = StringUtils.defaultString(result.address.koreliste); //Sikre at der ikke sendes "null" tilbage
+
+ String ruteSondag = StringUtils.defaultString(result.address.ruteSondag); //Sikre at der ikke sendes "null" tilbage
+ String korelisteSondag = StringUtils.defaultString(result.address.korelisteSondag); //Sikre at der ikke sendes "null" tilbage
+
+ sb.append("").append( result.status ).append("");
+
+ if (omdeling.equals("H")) { //Hverdag
+ sb.append("").append( rute ).append("");
+ sb.append("").append( koreliste ).append("");
+ } else {
+ sb.append("").append( ruteSondag ).append("");
+ sb.append("").append( korelisteSondag ).append("");
+ }
+
+
+ sb.append("").append(result.address.kommunekode).append("");
+ sb.append("").append(result.address.vejkode).append("");
+ sb.append("").append(result.address.dbkBane).append("");
+ sb.append("\n");
+
+ //Extra information
+ sb.append("");
+ sb.append("").append( result.splitResult.vej).append("");
+ sb.append("").append( result.splitResult.husnr).append("");
+ sb.append("").append( result.splitResult.litra).append("");
+ sb.append("").append( result.splitResult.etage).append(""); //sal
+ sb.append("").append( result.splitResult.lejlighed).append(""); //side
+ sb.append("");
+
+
+ sb.append("").append( result.gadeident ).append("");
+ sb.append("").append(result.vej).append("");
+
+ sb.append("").append(result.address.latitude).append("");
+ sb.append("").append(result.address.longitude).append("");
+
+ sb.append("").append(result.address.daekningsType).append("");
+ sb.append("").append(result.address.distributor).append("");
+ if (result.address.daekningsType == DaekningsType.DAEKNING_UDVIDET) {
+ sb.append("").append(result.address.extAfstand).append("");
+
+ Address t = result.address.extTarget;
+ sb.append("").append(t.vejnavn + " " + t.husnr + t.husnrbogstav + ", " + t.postnr).append("");
+ }
+
+
+ sb.append("").append(result.levenshtein).append("");
+
+ sb.append("").append(result.osm).append("");
+ sb.append("").append(result.osmVej).append("");
+
+ sb.append("").append(result.google).append("");
+ sb.append("").append(result.googleVej).append("");
+
+
sb.append("");
response.setContentType("text/xml; charset=UTF-8");
response.getWriter().print( sb );
+ logPersistance.saveRequestLog(brugerid, postnr, adresseStr, result);
+
+ }
+
+ private String generateErrorXML(String msg) {
+ StringBuilder sb = new StringBuilder();
+ sb.append("");
+ sb.append("error");
+ sb.append("").append(msg).append("");
+ sb.append("");
+
+ return sb.toString();
+
}
}