--- dao/DaoAdresseService/src/dk/daoas/daoadresseservice/SearchServlet.java 2015/02/13 13:48:09 2276
+++ dao/DaoAdresseService/src/dk/daoas/daoadresseservice/SearchServlet.java 2015/02/15 16:09:11 2301
@@ -9,13 +9,23 @@
import javax.servlet.http.HttpServletRequest;
import javax.servlet.http.HttpServletResponse;
-import dk.daoas.daoadresseservice.SearchResult.Status;
+import dk.daoas.daoadresseservice.beans.Address;
+import dk.daoas.daoadresseservice.beans.SearchResult;
+import dk.daoas.daoadresseservice.beans.SearchResult.Status;
/**
* Servlet implementation class SearchServlet
*/
-@WebServlet({ "/SearchServlet", "/search" })
+@WebServlet(urlPatterns = { "/SearchServlet", "/search" }, loadOnStartup = 1)
public class SearchServlet extends HttpServlet {
+
+ @Override
+ public void init() throws ServletException {
+ super.init();
+ System.out.println("SearchServlet loaded");
+ }
+
+
private static final long serialVersionUID = 1L;
String getUtf8(String str) throws UnsupportedEncodingException {
@@ -24,19 +34,28 @@
protected void doGet(HttpServletRequest request, HttpServletResponse response) throws ServletException, IOException {
+
AdressSearch search = (AdressSearch) this.getServletContext().getAttribute("search");
- request.setCharacterEncoding("UTF-8");
+ if (search == null) {
+ response.setContentType("text/xml; charset=UTF-8");
+ response.getWriter().print(
+ "error" +
+ "Service not ready"
+ );
+ return;
+
+ }
String brugerid = request.getParameter("brugerid");
String postnr = request.getParameter("postnr");
- String adresseStr = getUtf8( request.getParameter("adresse") );
-
- //System.out.println (">" + postnr + " | " + adresseStr);
+ //String adresseStr = getUtf8( request.getParameter("adresse") );
+ String adresseStr = request.getParameter("adresse");
SearchResult result = search.search(postnr, adresseStr);
+
StringBuilder sb = new StringBuilder();
- sb.append("");
+ sb.append("\n");
if (result.status == Status.STATUS_OK) {
sb.append("ok");
@@ -45,11 +64,21 @@
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("");
- sb.append("").append(result.address.extAfstand).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.osm).append("");
+ sb.append("").append(result.google).append("");
+
} else {
sb.append("error");
@@ -60,8 +89,6 @@
response.setContentType("text/xml; charset=UTF-8");
response.getWriter().print( sb );
-
-
}
}