Object userId = request.getSession().getAttribute("userId");
boolean isNot = frontOrderService.getByOrderNo(order.getOrder_no(),userId.toString());
String projectPath = ResourceUtil.getProjectPath();//获取项目访问路径
String notify_url = projectPath+"/vkeplus/frontPayAction!notify_url.action";
String return_url = projectPath+"/vkeplus/frontPayAction!return_alipay.action";
//String show_url = new String(request.getParameter("WIDshow_url").getBytes("ISO-8859-1"),"UTF-8");
String exter_invoke_ip = this.getIpAddr(request);
Map<String, String> sParaTemp = new HashMap<String, String>();
sParaTemp.put("service", "create_direct_pay_by_user");
sParaTemp.put("seller_email", AlipayConfig.seller_email);
sParaTemp.put("_input_charset", AlipayConfig.input_charset);
sParaTemp.put("anti_phishing_key", anti_phishing_key);
sParaTemp.put("exter_invoke_ip", exter_invoke_ip);
String sHtmlText = AlipaySubmit.buildRequest(sParaTemp,"get","确认");
/**
*//***********页面功能说明***********
* 该页面可在本机电脑测试
* TRADE_FINISHED(表示交易已经成功结束,并不能再对该交易作后续操做);
* TRADE_SUCCESS(表示交易已经成功结束,能够对该交易作后续操做,如:分润、退款等);
* guowb
* 20150714
* 支付宝页面跳转同步通知
*/
@Deprecated
public String return_alipay(){
try {
//获取支付宝GET过来反馈信息
Map<String,String> params = new HashMap<String,String>();
Map requestParams = request.getParameterMap();
for (Iterator iter = requestParams.keySet().iterator(); iter.hasNext();) {
String name = (String) iter.next();
String[] values = (String[]) requestParams.get(name);
String valueStr = "";
for (int i = 0; i < values.length; i++) {
valueStr = (i == values.length - 1) ? valueStr + values[i]
: valueStr + values[i] + ",";
}
//乱码解决,这段代码在出现乱码时使用。若是mysign和sign不相等也可使用这段代码转化
valueStr = new String(valueStr.getBytes("ISO-8859-1"), "utf-8");
params.put(name, valueStr);
}
//获取支付宝的通知返回参数,可参考技术文档中页面跳转同步通知参数列表(如下仅供参考)//
//商户订单号
String out_trade_no = new String(request.getParameter("out_trade_no").getBytes("ISO-8859-1"),"UTF-8");
//支付宝交易号
String trade_no = new String(request.getParameter("trade_no").getBytes("ISO-8859-1"),"UTF-8");
//交易状态
String trade_status = new String(request.getParameter("trade_status").getBytes("ISO-8859-1"),"UTF-8");
//交易金额
String total_fee = new String(request.getParameter("total_fee").getBytes("ISO-8859-1"),"UTF-8");
String buyer_email = new String(request.getParameter("buyer_email").getBytes("ISO-8859-1"),"UTF-8");
//客户端ip
String exter_invoke_ip = this.getIpAddr(request);
//获取支付宝的通知返回参数,可参考技术文档中页面跳转同步通知参数列表(以上仅供参考)//
//计算得出通知验证结果
boolean verify_result = AlipayNotify.verify(params);
if(verify_result){//验证成功
boolean isNot = frontOrderService.getByOrderNo(out_trade_no,null);
if(isNot){//存在\
order.setOrder_no(out_trade_no);
Order o = frontOrderService.getByOrder(order);
if(o.getPay_status().equals("2")){//已支付
request.setAttribute("total_fee", total_fee);
request.setAttribute("order_no", out_trade_no);
request.setAttribute("platformType", o.getPlatformType());
return "pay_success";
}else{
//——请根据您的业务逻辑来编写程序(如下代码仅做参考)——
if(trade_status.equals("TRADE_FINISHED") || trade_status.equals("TRADE_SUCCESS")){
List<Ordergools> ogList = ordergoolsService.getOrdergoolsList(o.getId());
if(ogList!=null && ogList.size()>0){
for(int i=0;i<ogList.size();i++){
if(!ogList.get(i).getVideoId().equals("0")){//不等于0 购买的视频
Video v = videoService.getById(ogList.get(i).getVideoId(), null);
if(v==null){
String msg = "error:[002]没有该视频,请联系客服处理,您的订单号为:"+out_trade_no+",支付宝单号为:"+trade_no+",交易状态为:"+trade_status;
request.setAttribute("msg", msg);
return "return_alipay";
}
}else{//
if(ogList.get(i).getGoodsType().equals("2")){//课程
Course c = courseService.getCourserById(ogList.get(i).getGoodsId());
if(c==null){
String msg = "error:[003]没有该课程,请联系客服处理,您的订单号为:"+out_trade_no+",支付宝单号为:"+trade_no+",交易状态为:"+trade_status;
request.setAttribute("msg", msg);
return "return_alipay";
}
}else if(ogList.get(i).getGoodsType().equals("0")){//套餐
Meal m = frontMealService.getById(ogList.get(i).getGoodsId());
if(m==null){
String msg = "error:[003]没有该套餐,请联系客服处理,您的订单号为:"+out_trade_no+",支付宝单号为:"+trade_no+",交易状态为:"+trade_status;
request.setAttribute("msg", msg);
return "return_alipay";
}
}
}
}
}
Date t = new Date();
try{
Order order = new Order();
//修改订单状态
order.setPay_status("2");//支付成功!
order.setOrder_status("1");//订单状态 完成
order.setPay_number(buyer_email);//支付者帐户
order.setPnumber(trade_no);//第三方支付订单号
order.setPmoney(Double.parseDouble(total_fee)*100);//到帐金额
order.setPtime(t);
order.setPtype("1");//支付宝支付
order.setUser_ip(exter_invoke_ip);//用户支付IP
frontOrderService.edit(o,order);
//fxw 20151117 支付订单到PHP
//参数集
String parm = "out_trade_no="+out_trade_no;//订单号
parm +="&buyer_email="+URLEncoder.encode(buyer_email,"utf-8");//支付者帐户
parm +="&trade_no="+trade_no;//第三方支付订单号
parm +="&total_fee="+total_fee;//到帐金额 (单位:分)
parm +="&exter_invoke_ip="+exter_invoke_ip;//Ip
HttpUtil.httpURLConnectionPOST(PhpParam.PAY_ORDER, parm);
int i=Math.round(Float.parseFloat(total_fee));//按消费金额取整
//购买送积分 fxw 20150915
ScoreDetail sd = new ScoreDetail();
User user = new User();
user.setCid(o.getUserId());
sd.setUserid(o.getUserId());
sd.setUsername(frontUserService.getUserById(user).getCname());
sd.setStatus(0);//消费
sd.setScorevalue(i);//金额
sd.setUri("/frontPayAction");
scoreDetailService.givingScore(sd);
} catch (Exception e) {
payLog.error(ExceptionUtil.getExceptionMessage(e));
String msg = "error:[005]订单状态修改失败,请联系客服处理,您的订单号为:"+out_trade_no+",支付宝单号为:"+trade_no+",交易状态为:"+trade_status;
request.setAttribute("msg", msg);
return "return_alipay";
}
//发送邮件
String toEmail = ResourceUtil.toEmail();//接收邮件邮箱
String subject = "用户成功提交了订单【"+out_trade_no+"】的支付宝交易确认";
StringBuffer sb=new StringBuffer("<b>用户成功提交了订单【"+out_trade_no+"】的支付宝交易确认</b><br><br>");
sb.append("<table border=\"1\"><tr><td width=\"100px\">订单号:</td><td width=\"400px\">"+out_trade_no+"</td></tr>");
sb.append("<tr><td>支付宝交易号:</td><td>"+trade_no+"</td></tr>");
// java.text.DecimalFormat df =new java.text.DecimalFormat("#.00");
// sb.append("<tr><td>实际需支付金额:</td><td>¥"+df.format(o.getOrder_money()/100)+"</td></tr>");
sb.append("<tr><td>实际需支付金额:</td><td>¥"+total_fee+"</td></tr>");
sb.append("<tr><td>确认金额:</td><td>¥"+total_fee+"</td></tr>");
sb.append("<tr><td>付款方式:</td><td>支付宝</td></tr>");
sb.append("<tr><td>支付者账号:</td><td>"+buyer_email+"</td></tr>");
sb.append("<tr><td>下单时间:</td><td>"+TimeUtil.dateString(o.getOrder_time())+"</td></tr>");
sb.append("<tr><td>付款时间:</td><td>"+TimeUtil.dateString(t)+"</td></tr>");
sb.append("</table><br><br>");
SendEmail.send(toEmail,subject, sb.toString());//发送
request.setAttribute("total_fee", total_fee);
request.setAttribute("order_no", out_trade_no);
request.setAttribute("platformType", o.getPlatformType());
return "pay_success";
}else{
String msg = "error:[006]交易途中出现错误致使交易失败,请联系客服处理,您的订单号为:"+out_trade_no+",支付宝单号为:"+trade_no+",交易状态为:"+trade_status;
request.setAttribute("msg", msg);
return "return_alipay";
}
}
}else{
String msg = "error:[001]查无此订单信息,请联系客服处理,您的订单号为:"+out_trade_no+",支付宝单号为:"+trade_no+",交易状态为:"+trade_status;
request.setAttribute("msg", msg);
}
}else{
String msg = "error:[007]支付宝验证失败,请联系客服处理,您的订单号为:"+out_trade_no+",支付宝单号为:"+trade_no+",交易状态为:"+trade_status;
request.setAttribute("msg", msg);
return "return_alipay";
}
} catch (Exception e) {
String msg = "error:[008]支付异常,请联系客服处理";
request.setAttribute("msg", msg);
}
return "return_alipay";
}
/**
* //***********页面功能说明***********
* 该页面不能在本机电脑测试,请到服务器上作测试。请确保外部能够访问该页面。
* 该页面调试工具请使用写文本函数logResult,该函数在com.alipay.util文件夹的AlipayNotify.java类文件中
* 若是没有收到该页面返回的 success 信息,支付宝会在24小时内按必定的时间策略重发通知
* guowb
* 20150715
* 支付宝服务器异步通知
*/
public void notify_url(){
//记录日志 入文件
PayLog pl = new PayLog();
pl.setPayType("1");
try{
PrintWriter out=ServletActionContext.getResponse().getWriter();
//获取支付宝POST过来反馈信息
Map<String,String> params = new HashMap<String,String>();
Map requestParams = request.getParameterMap();
for (Iterator iter = requestParams.keySet().iterator(); iter.hasNext();) {
String name = (String) iter.next();
String[] values = (String[]) requestParams.get(name);
String valueStr = "";
for (int i = 0; i < values.length; i++) {
valueStr = (i == values.length - 1) ? valueStr + values[i]
: valueStr + values[i] + ",";
}
//乱码解决,这段代码在出现乱码时使用。若是mysign和sign不相等也可使用这段代码转化
//valueStr = new String(valueStr.getBytes("ISO-8859-1"), "gbk");
params.put(name, valueStr);
}
//获取支付宝的通知返回参数,可参考技术文档中页面跳转同步通知参数列表(如下仅供参考)//
//商户订单号
String out_trade_no = new String(request.getParameter("out_trade_no").getBytes("ISO-8859-1"),"UTF-8");
pl.setVyankeOrder(out_trade_no);
//支付宝交易号
String trade_no = new String(request.getParameter("trade_no").getBytes("ISO-8859-1"),"UTF-8");
pl.setThirdPartOrder(trade_no);
//交易状态
String trade_status = new String(request.getParameter("trade_status").getBytes("ISO-8859-1"),"UTF-8");
//交易金额
String total_fee = new String(request.getParameter("total_fee").getBytes("ISO-8859-1"),"UTF-8");
pl.setOrderMoney(total_fee);//交易金额(元)
String buyer_email = new String(request.getParameter("buyer_email").getBytes("ISO-8859-1"),"UTF-8");
//客户端ip
String exter_invoke_ip = this.getIpAddr(request);
//获取支付宝的通知返回参数,可参考技术文档中页面跳转同步通知参数列表(以上仅供参考)//
if(AlipayNotify.verify(params)){//验证成功
boolean isNot = frontOrderService.getByOrderNo(out_trade_no,null);
if(isNot){//存在\
order.setOrder_no(out_trade_no);
Order o = frontOrderService.getByOrder(order);
pl.setOrderName(o.getOrder_name());//订单名
pl.setGoodsName(o.getOrder_remarks());//订单备注
if(o.getPay_status().equals("2")){//已支付
String msg = "error:[000]已支付过,请联系客服处理,您的订单号为:"+out_trade_no+",支付宝单号为:"+trade_no+",交易状态为:"+trade_status;
request.setAttribute("msg", msg);
out.println("fail");
}else{
//判断该笔订单是否在商户网站中已经作过处理
//若是没有作过处理,根据订单号(out_trade_no)在商户网站的订单系统中查到该笔订单的详细,并执行商户的业务程序
//若是有作过处理,不执行商户的业务程序
/*if(trade_status.equals("TRADE_FINISHED")){
//注意:
//退款日期超过可退款期限后(如三个月可退款),支付宝系统发送该交易状态通知
} else if (trade_status.equals("TRADE_SUCCESS")){
//注意:
//付款完成后,支付宝系统发送该交易状态通知
}
*/
//——请根据您的业务逻辑来编写程序(如下代码仅做参考)——
if(trade_status.equals("TRADE_FINISHED") || trade_status.equals("TRADE_SUCCESS")){
pl.setPayStatus("0");//支付成功
List<Ordergools> ogList = ordergoolsService.getOrdergoolsList(o.getId());
if(ogList!=null && ogList.size()>0){
for(int i=0;i<ogList.size();i++){
if(!ogList.get(i).getVideoId().equals("0")){//不等于0 购买的视频
Video v = videoService.getById(ogList.get(i).getVideoId(), null);
if(v==null){
String msg = "error:[002]没有该视频,请联系客服处理,您的订单号为:"+out_trade_no+",支付宝单号为:"+trade_no+",交易状态为:"+trade_status;
request.setAttribute("msg", msg);
out.println("fail");
}
}else{//
if(ogList.get(i).getGoodsType().equals("2")){//课程
Course c = courseService.getCourserById(ogList.get(i).getGoodsId());
if(c==null){
String msg = "error:[003]没有该课程,请联系客服处理,您的订单号为:"+out_trade_no+",支付宝单号为:"+trade_no+",交易状态为:"+trade_status;
request.setAttribute("msg", msg);
out.println("fail");
}else {
//by lwj : 2015/9/1 ( 购买数量更新 )
String update = this.courseService
.updateView_BuyNums(new Course(ogList.get(i).getGoodsId(),"buy"));
payLog.info("当前课程:"+ogList.get(i).getGoodsId()+",购买数量更新状态:" + update);
}
}else if(ogList.get(i).getGoodsType().equals("0")){//套餐
Meal m = frontMealService.getById(ogList.get(i).getGoodsId());
if(m==null){
String msg = "error:[003]没有该套餐,请联系客服处理,您的订单号为:"+out_trade_no+",支付宝单号为:"+trade_no+",交易状态为:"+trade_status;
request.setAttribute("msg", msg);
out.println("fail");
}
}
}
}
}
Date t = new Date();
try{
Order order = new Order();
//修改订单状态
order.setPay_status("2");//支付成功!
order.setOrder_status("1");//订单状态 完成
order.setPay_number(buyer_email);
order.setPnumber(trade_no);
order.setPmoney(Double.parseDouble(total_fee)*100);//
order.setPtime(t);
pl.setOrderTime(DateUtils.format(t, "yyyy-MM-dd HH:mm:ss"));//日志
order.setPtype("1");//支付宝支付
order.setUser_ip(exter_invoke_ip);//用户支付IP
frontOrderService.edit(o,order);
//fxw 20151117 支付订单到PHP
//参数集
String parm = "out_trade_no="+out_trade_no;//订单号
parm +="&buyer_email="+URLEncoder.encode(buyer_email,"utf-8");//支付者帐户
parm +="&trade_no="+trade_no;//第三方支付订单号
parm +="&total_fee="+total_fee;//到帐金额 (单位:分)
parm +="&exter_invoke_ip="+exter_invoke_ip;//Ip
//调用PHP同步接口
String callback =HttpUtil.httpURLConnectionReturnPOST(PhpParam.PAY_ORDER, parm);
JSONObject resJson = AppJson.toJson((callback.replace("callback(", "")).replace(")", ""));
String ret = resJson.getString("ret");
//PHP返回状态:0同步成功;1添加失败;2已购买;3课程不存在;4用户不存在5:课程ID为空
if(!"0".equals(ret)){
//添加同步失败记录
System.out.println("同步失败---编码为"+ret);
//经过条件查询用户
User syncuser = userService.getUserByName(o.getUsername());
//同步出错添加同步记录表
SyncDataInfo su = new SyncDataInfo();
//用户名
su.setUsername(syncuser.getCname());
//同步状态
su.setStatus(ret);
//用户手机号
su.setMobilephone(syncuser.getUserInfo().getPhone());
//同步类型:订单支付同步
su.setSynctype("2");
su.setRemark("系统同步订单支付状态");//修改
syncDataInfoService.addSyncDataInfo(su);
}
int i=Math.round(Float.parseFloat(total_fee));//按消费金额取整
//购买送积分 fxw 20150915
ScoreDetail sd = new ScoreDetail();
User user = new User();
user.setCid(o.getUserId());
sd.setUserid(o.getUserId());
User userById = frontUserService.getUserById(user);
sd.setUsername(userById.getCname()); // 用户名
pl.setUsername(userById.getCname());//日志:用户名
UserInfo userInfo = userById.getUserInfo();
if(userInfo!=null){
pl.setPhone(userInfo.getPhone());//日志:手机号
}
sd.setStatus(0);//消费
sd.setScorevalue(i);//金额
sd.setUri("/frontPayAction");
scoreDetailService.givingScore(sd);
} catch (Exception e) {
payLog.error(ExceptionUtil.getExceptionMessage(e));
String msg = "error:[005]订单状态修改失败,请联系客服处理,您的订单号为:"+out_trade_no+",支付宝单号为:"+trade_no+",交易状态为:"+trade_status;
request.setAttribute("msg", msg);
out.println("fail");
}
//发送邮件
String toEmail = ResourceUtil.toEmail();//接收邮件邮箱
String subject = "用户成功提交了订单【"+out_trade_no+"】的支付宝交易确认";
StringBuffer sb=new StringBuffer("<b>用户成功提交了订单【"+out_trade_no+"】的支付宝交易确认</b><br><br>");
sb.append("<table border=\"1\"><tr><td width=\"100px\">订单号:</td><td width=\"400px\">"+out_trade_no+"</td></tr>");
sb.append("<tr><td>支付宝交易号:</td><td>"+trade_no+"</td></tr>");
// java.text.DecimalFormat df =new java.text.DecimalFormat("#.00");
// sb.append("<tr><td>实际需支付金额:</td><td>¥"+df.format(o.getOrder_money()/100)+"</td></tr>");
sb.append("<tr><td>实际需支付金额:</td><td>¥"+total_fee+"</td></tr>");
sb.append("<tr><td>确认金额:</td><td>¥"+total_fee+"</td></tr>");
sb.append("<tr><td>付款方式:</td><td>支付宝</td></tr>");
sb.append("<tr><td>支付者账号:</td><td>"+buyer_email+"</td></tr>");
sb.append("<tr><td>下单时间:</td><td>"+TimeUtil.dateString(o.getOrder_time())+"</td></tr>");
sb.append("<tr><td>付款时间:</td><td>"+TimeUtil.dateString(t)+"</td></tr>");
sb.append("</table><br><br>");
SendEmail.send(toEmail,subject, sb.toString());//发送
String msg = "success:支付成功,您的订单号为:"+out_trade_no+",支付宝单号为:"+trade_no+",交易状态为:"+trade_status;
request.setAttribute("msg", msg);
out.println("success");
}else{
pl.setPayStatus("1");//支付失败
String msg = "error:[006]交易途中出现错误致使交易失败,请联系客服处理,您的订单号为:"+out_trade_no+",支付宝单号为:"+trade_no+",交易状态为:"+trade_status;
request.setAttribute("msg", msg);
out.println("fail");
}
}
}else{
String msg = "error:[001]查无此订单信息,请联系客服处理,您的订单号为:"+out_trade_no+",支付宝单号为:"+trade_no+",交易状态为:"+trade_status;
request.setAttribute("msg", msg);
out.println("fail");
}
}else{//验证失败
String msg = "error:[007]支付宝验证失败,请联系客服处理,您的订单号为:"+out_trade_no+",支付宝单号为:"+trade_no+",交易状态为:"+trade_status;
request.setAttribute("msg", msg);
out.println("fail");
}
} catch (Exception e) {
String msg = "error:[008]支付异常,请联系客服处理";
request.setAttribute("msg", msg);
}
//记录日志
System.out.println("记录日志:--------------");
payLog.debug("记录日志:--------------");
payLog.debug(pl.toString());
}