--- dao/DaoAdresseService/src/dk/daoas/daoadresseservice/SearchServlet.java 2015/02/14 08:54:43 2290 +++ dao/DaoAdresseService/src/main/java/dk/daoas/daoadresseservice/SearchServlet.java 2016/03/07 20:40:40 2966 @@ -1,7 +1,8 @@ package dk.daoas.daoadresseservice; import java.io.IOException; -import java.io.UnsupportedEncodingException; +import java.util.Arrays; +import java.util.List; import javax.servlet.ServletException; import javax.servlet.annotation.WebServlet; @@ -9,82 +10,255 @@ 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; + + private List omdelingsTyper = Arrays.asList( new String[] { + "H","L","S", //de gamle + "MA","TI","ON","TO","FR","LO","SO" + } ); + @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 { -//long start1 = System.currentTimeMillis(); - AdressSearch search = (AdressSearch) this.getServletContext().getAttribute("search"); - request.setCharacterEncoding("UTF-8"); + + response.setHeader("Access-Control-Allow-Origin", "*"); //Allow ajax calls from everywhere + + AddressSearch search = (AddressSearch) this.getServletContext().getAttribute("search"); + if (search == null) { + System.out.println("Recieved request while loading data"); + + response.setContentType("text/xml; charset=UTF-8"); + 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"); + + + String naermesteHusnrStr = request.getParameter("naermestehusnr"); + + 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"; + } + omdeling = omdeling.toUpperCase(); + + if ( omdelingsTyper.contains(omdeling) == false ) { + response.setContentType("text/xml; charset=UTF-8"); + response.getWriter().print( generateErrorXML("Ugyldig omdelingsdag") ); + return; + } + boolean naermesteHusnr; + if (naermesteHusnrStr == null || naermesteHusnrStr.equals("")) { + naermesteHusnr = false; + } else { + naermesteHusnr = Integer.parseInt( naermesteHusnrStr ) > 0; + } + + -//long start2 = System.currentTimeMillis(); - SearchResult result = search.search(postnr, adresseStr); + SearchResult result = search.search(postnr, adresseStr, naermesteHusnr); -//long start3 = System.currentTimeMillis(); StringBuilder sb = new StringBuilder(); - sb.append(""); + sb.append("\n"); 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(""); - - //Extra information - 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).append(""); - } - } else { sb.append("error"); - sb.append("").append( result.status ).append(""); } + + String ruteMandag = StringUtils.defaultString(result.address.routingMandag.rute); //Sikre at der ikke sendes "null" tilbage + String korelisteMandag = StringUtils.defaultString(result.address.routingMandag.koreliste); //Sikre at der ikke sendes "null" tilbage + String ruteTirsdag = StringUtils.defaultString(result.address.routingTirsdag.rute); //Sikre at der ikke sendes "null" tilbage + String korelisteTirsdag = StringUtils.defaultString(result.address.routingTirsdag.koreliste); //Sikre at der ikke sendes "null" tilbage + String ruteOnsdag = StringUtils.defaultString(result.address.routingOnsdag.rute); //Sikre at der ikke sendes "null" tilbage + String korelisteOnsdag = StringUtils.defaultString(result.address.routingOnsdag.koreliste); //Sikre at der ikke sendes "null" tilbage + String ruteTorsdag = StringUtils.defaultString(result.address.routingTorsdag.rute); //Sikre at der ikke sendes "null" tilbage + String korelisteTorsdag = StringUtils.defaultString(result.address.routingTorsdag.koreliste); //Sikre at der ikke sendes "null" tilbage + String ruteFredag = StringUtils.defaultString(result.address.routingFredag.rute); //Sikre at der ikke sendes "null" tilbage + String korelisteFredag = StringUtils.defaultString(result.address.routingFredag.koreliste); //Sikre at der ikke sendes "null" tilbage + + String ruteLordag = StringUtils.defaultString(result.address.routingLordag.rute); //Sikre at der ikke sendes "null" tilbage + String korelisteLordag = StringUtils.defaultString(result.address.routingLordag.koreliste); //Sikre at der ikke sendes "null" tilbage + + String ruteSondag = StringUtils.defaultString(result.address.routingSondag.rute); //Sikre at der ikke sendes "null" tilbage + String korelisteSondag = StringUtils.defaultString(result.address.routingSondag.koreliste); //Sikre at der ikke sendes "null" tilbage + + sb.append("").append( result.status ).append(""); + + + + String valgtRute = ruteMandag; //Default til hverdag/mandags oplysningerne + String valgtKoreliste = korelisteMandag; + + if (omdeling.equals("TI") && ruteTirsdag.equals("") == false){ + valgtRute = ruteTirsdag; + valgtKoreliste = korelisteTirsdag; + } + if (omdeling.equals("ON") && ruteOnsdag.equals("") == false){ + valgtRute = ruteOnsdag; + valgtKoreliste = korelisteOnsdag; + } + if (omdeling.equals("TO") && ruteTorsdag.equals("") == false){ + valgtRute = ruteTorsdag; + valgtKoreliste = korelisteTorsdag; + } + if (omdeling.equals("FR") && ruteFredag.equals("") == false){ + valgtRute = ruteFredag; + valgtKoreliste = korelisteFredag; + } + if ( (omdeling.equals("L") || omdeling.equals("LO")) && ruteLordag.equals("") == false){ + valgtRute = ruteLordag; + valgtKoreliste = korelisteLordag; + } + if ( (omdeling.equals("S") || omdeling.equals("SO")) && ruteSondag.equals("") == false) { + valgtRute = ruteSondag; + valgtKoreliste = korelisteSondag; + } + + sb.append("").append( valgtRute ).append(""); + sb.append("").append( valgtKoreliste ).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.vasketVejnavn ).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).append(""); + sb.append("").append(t.postnr).append(""); + sb.append("").append(t.latitude).append(",").append(t.longitude).append(""); + } + + sb.append("").append(ruteMandag).append(" ").append(korelisteMandag).append(""); + sb.append("").append(ruteMandag).append(" ").append(korelisteMandag).append(""); + sb.append("").append(ruteMandag).append(" ").append(korelisteMandag).append(""); + sb.append("").append(ruteMandag).append(" ").append(korelisteMandag).append(""); + sb.append("").append(ruteMandag).append(" ").append(korelisteMandag).append(""); + sb.append("").append(ruteLordag).append(" ").append(korelisteLordag).append(""); + sb.append("").append(ruteSondag).append(" ").append(korelisteSondag).append(""); + + + + sb.append("").append(result.nearestHusnr).append(""); + sb.append("").append(result.anvendtHusnr).append(""); + sb.append("").append(result.nearestLitra).append(""); + + + sb.append("").append(result.levenshtein).append(""); + sb.append("").append(result.levenshteinDistance).append(""); + + sb.append("").append(result.metaphone).append(""); + sb.append("").append(result.metaphoneVej).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(search.getDatabaseLayer(), brugerid, postnr, adresseStr, omdeling, result); + + } -/* -long start4 = System.currentTimeMillis(); -System.out.println("Servlet2:" + (start2-start1) ); -System.out.println("Servlet3:" + (start3-start1) ); -System.out.println("Servlet4:" + (start4-start1) ); -*/ + public static String generateErrorXML(String msg) { + StringBuilder sb = new StringBuilder(); + sb.append(""); + sb.append("error"); + sb.append("").append(msg).append(""); + sb.append(""); + return sb.toString(); + } }