package com.j1.mai.action; import java.io.BufferedReader; import java.io.DataOutputStream; import java.io.IOException; import java.io.InputStream; import java.io.InputStreamReader; import java.net.HttpURLConnection; import java.net.URL; import java.util.HashMap; import java.util.Iterator; import java.util.Map; import javax.servlet.http.HttpServletRequest; import javax.servlet.http.HttpServletResponse; import net.sf.json.JSONObject; import org.apache.log4j.Logger; import org.springframework.context.annotation.Scope; import org.springframework.stereotype.Controller; import org.springframework.web.bind.annotation.RequestMapping; import org.springframework.web.bind.annotation.RequestParam; import org.springframework.web.bind.annotation.ResponseBody; import com.alibaba.fastjson.JSON; import com.alibaba.fastjson.JSONArray; import com.j1.base.type.MsgStatus; import com.j1.mai.model.common.SoaApiBaseAction; import com.j1.mai.util.PropertyConfigurer; import com.j1.soa.common.DateUtils; import com.j1.soa.common.Md5Util; @Controller @Scope("request") @RequestMapping("/storeConsumptionLogin") public class StoreLoginAction extends SoaApiBaseAction { // final static String url ="http://localhost:8080/httpServer/c_i/common_i"; static Logger LOG = Logger.getLogger(StoreLoginAction.class); @RequestMapping("/login") public Object loginStoreConsumption( HttpServletRequest request, HttpServletResponse response, @RequestParam(value = "empName", required = true) String empName,// 用戶名 @RequestParam(value = "loginPassWd", required = true) String loginPassWd// 密碼 ) { /** * 調用接口 */ Map<String, Object> mapRes = new HashMap<String, Object>(); // 讀取配置文件 String promoteUrl =(String)PropertyConfigurer.getString("storeConsumptiondLoginUrl"); String message = null; JSONObject jsonObject = null; message = httpSend(promoteUrl, empName, loginPassWd); try { // 解析json字符串 message = message.replaceAll("\\\\", ""); String jsonStr = message.substring(message.indexOf("[") + 1, message.indexOf("]")); jsonObject = JSONObject.fromObject(jsonStr); String responseCode = jsonObject.getString("msg"); if (responseCode.equals("用戶名或密碼錯誤")) { mapRes.put("status", 1); mapRes.put("msg", "loginFalse"); } else { mapRes.put("status", 0); mapRes.put("msg", "ok"); } } catch (Exception e) { e.printStackTrace(); } finally { /** *將操做的我的信息存在Session中,傳給前臺 *以便於在前臺在錄入會員的時候傳遞到後臺 */ //操做人名稱 String empNameAdd=jsonObject.getString("empName"); //操做門店名稱 String deptNameAdd=jsonObject.getString("deptName"); //門店編碼 String deptNo=jsonObject.getString("deptNo"); //登陸名 String loginName=jsonObject.getString("loginName"); //操做人ID String empId=jsonObject.getString("empId"); request.getSession().setAttribute("empNameAdd", empNameAdd); request.getSession().setAttribute("deptNameAdd", deptNameAdd); request.getSession().setAttribute("deptNo",deptNo ); request.getSession().setAttribute("empId", empId); request.getSession().setAttribute("loginName", loginName); // this.write(request, response); } JSON o=(JSON) com.alibaba.fastjson.JSONObject.toJSON(mapRes); System.out.println("查看=============="+o); return com.alibaba.fastjson.JSONObject.toJSON(mapRes); } /** * 發送HTTP請求 * * @param url * @param propsMap * 發送的參數 */ public String httpSend(String promoteUrl, String empName, String loginPassWd) { StringBuffer buffer = new StringBuffer(); String responseContent = null; try { URL url_new = new URL(promoteUrl);// 建立鏈接 HttpURLConnection connection = (HttpURLConnection) url_new .openConnection(); connection.setDoOutput(true); connection.setDoInput(true); connection.setRequestMethod("POST"); connection.setUseCaches(false); connection.setInstanceFollowRedirects(true); connection.setRequestProperty("Accept", "application/json"); // 設置接收數據的格式 connection.setRequestProperty("Content-Type", "application/json"); // 設置發送數據的格式 connection.connect(); // POST請求 DataOutputStream out = new DataOutputStream( connection.getOutputStream()); // utf-8編碼 ; String sign = null; String time = DateUtils.longToDateAll(System.currentTimeMillis()); String token = "91A1643059824847938125BA0AC0F557"; // token 不產於傳送 String format = "json"; // 傳送方式 String method = "queryTbl_Employee";// 調用方法 String sessionKey = "123456789078945";// sessionkey String up_date = time;// 上傳日期 yyyy-mm-dd String version = "1.0.2";// 版本號 try { sign = Md5Util.Bit32(format + method + sessionKey + token + up_date + version); } catch (Exception e1) { e1.printStackTrace(); } JSONObject obj = new JSONObject(); obj.element("sessionKey", sessionKey); obj.element("method", method); obj.element("format", format); obj.element("up_Date", time); obj.element("sign", sign); obj.element("version", version); JSONObject objbusinessdate = new JSONObject(); objbusinessdate.element("username", empName);// username , objbusinessdate.element("password", loginPassWd); // password obj.element("businessData", objbusinessdate); System.out.println(obj.toString()); out.writeBytes(obj.toString()); out.flush(); // 讀取響應 int length = (int) connection.getContentLength();// 獲取長度 System.out.println("length:" + length); if (connection.getResponseCode() != HttpURLConnection.HTTP_OK) { System.out.println("網絡錯誤異常!!!!"); } InputStream in = connection.getInputStream(); BufferedReader rds = new BufferedReader(new InputStreamReader(in, "UTF-8")); String tempLine = rds.readLine(); StringBuffer tempStr = new StringBuffer(); if (tempLine != null) { tempStr.append(tempLine); tempLine = rds.readLine(); } responseContent = tempStr.toString(); // BufferedReader rd = new BufferedReader(new InputStreamReader( // connection.getInputStream(), "UTF-8")); // while( (responseMsg = rd.readLine())!=null){ // buffer.append(responseMsg); // // } out.close(); rds.close(); connection.disconnect(); System.out.println(" Buffer============= " + buffer.toString()); return responseContent; } catch (IOException e) { e.printStackTrace(); } // return buffer.toString(); // 自定義錯誤信息 return responseContent; // 自定義錯誤信息 } }