使用后端進行數據判斷。
專注于為中小企業提供成都做網站、網站制作服務,電腦端+手機端+微信端的三站合一,更高效的管理,為中小企業桃山免費做網站提供優質的服務。我們立足成都,凝聚了一批互聯網行業人才,有力地推動了上千家企業的穩健成長,幫助中小企業通過網站建設實現規模擴充和轉變。
首先在后端平臺設置銀行卡賬號和密碼用來判斷支付,支付完成后,建行會自動調用回調地址,這個地址是在建行商戶平臺配置的,反饋有兩種,網頁反饋和服務器反饋,頁面反饋付款人付款完成后,點擊返回商戶網站按鈕,觸發頁面反饋,服務器反饋只要支付成功,無需觸發,由建行支付網關,以post 方法,發信息給反饋URL還分為網上銀行和手機銀行反饋,網上銀行就是微信支付寶調用url支付,手機銀行就是建行手機銀行支付客戶端,其實手機、網銀,區分不是很嚴格,一般都設置成一樣的,同一筆支付,可能會觸發多渠道的同時反饋,所以,反饋機制,在響應的時候,是允許重復的,一般來說,服務器,頁面,是寫成兩個不同的回調處理,或者,加個條件判斷,同時允許post和get,寫成一個,就不太好判斷反饋的來源了,寫成兩個,再通過日志,能區分反饋的來源。
import java.util.ArrayList;
public class Du {
public static void main(String[] args) throws Exception {
Seller seller = new Seller("My Store");
seller.addGoods("T-shirt", 200);
seller.addGoods("Pill", 100);
seller.addGoods("T-shirt", 100);
seller.addGoods("T-shirt", 50);
seller.addGoods("Pill", 50);
seller.addGoods("Hat", 100);
seller.printGoods();
Seller sell2 = new Seller("The Other Store");
sell2.addGoods("T-shirt", 200);
sell2.addGoods("Hat", 100);
sell2.sellGoods("T-shirt", 50);
sell2.addGoods("Hat", 100);
sell2.printGoods();
}
}
class Seller {
private String sellerName;
private int TotalTypeOfGoods;
private ArrayListString goodsNameList = new ArrayListString();
private ArrayListInteger goodsQuantityList = new ArrayListInteger();
public Seller(String sellerName) {
this.sellerName = sellerName;
}
public void addGoods(String goodName, int goodNum) {
int index = goodsNameList.indexOf(goodName);
if (index == -1) {
goodsNameList.add(goodName);
goodsQuantityList.add(new Integer(goodNum));
} else {
goodsQuantityList.set(index, goodsQuantityList.get(index)
.intValue()
+ goodNum);
}
TotalTypeOfGoods = goodsNameList.size();
}
public void sellGoods(String goodName, int goodNum) throws Exception {
if (TotalTypeOfGoods == 0) {
throw new Exception("No goods provided by the shop. Closed!");
}
int index = goodsNameList.indexOf(goodName);
if (index != -1) {
int qty = goodsQuantityList.get(index);
if (goodNum qty) {
throw new Exception("Insufficient goods in the shop. Sorry!");
}
goodsQuantityList.set(index, qty - goodNum);
}else{
throw new Exception("Our shop doesn't sell " + goodName);
}
}
public void printGoods() {
System.out.print("Seller :" + this.sellerName + "\t");
System.out.println("Totoal Types of Goods is :" + this.TotalTypeOfGoods);
for(int i = 0; i goodsNameList.size(); i++){
System.out.print("Goods Name: " + goodsNameList.get(i));
System.out.println("Remains: " + goodsQuantityList.get(i));
}
System.out.println();
}
}
-----------------testing
Seller :My Store Totoal Types of Goods is :3
Goods Name: T-shirtRemains: 350
Goods Name: PillRemains: 150
Goods Name: HatRemains: 100
Seller :The Other Store Totoal Types of Goods is :2
Goods Name: T-shirtRemains: 150
Goods Name: HatRemains: 200
package beans.excel;
import java.io.IOException;
import java.io.OutputStream;
import jxl.Workbook;
import jxl.write.Label;
import jxl.write.WritableSheet;
import jxl.write.WritableWorkbook;
import jxl.write.WriteException;
public class SimpleExcelWrite {
public void createExcel(OutputStream os) throws WriteException,IOException{
//創建工作薄
WritableWorkbook workbook = Workbook.createWorkbook(os);
//創建新的一頁
WritableSheet sheet = workbook.createSheet("First Sheet",0);
//創建要顯示的內容,創建一個單元格,第一個參數為列坐標,第二個參數為行坐標,第三個參數為內容
Label xuexiao = new Label(0,0,"學校");
sheet.addCell(xuexiao);
Label zhuanye = new Label(1,0,"專業");
sheet.addCell(zhuanye);
Label jingzhengli = new Label(2,0,"專業競爭力");
sheet.addCell(jingzhengli);
Label qinghua = new Label(0,1,"清華大學");
sheet.addCell(qinghua);
Label jisuanji = new Label(1,1,"計算機專業");
sheet.addCell(jisuanji);
Label gao = new Label(2,1,"高");
sheet.addCell(gao);
Label beida = new Label(0,2,"北京大學");
sheet.addCell(beida);
Label falv = new Label(1,2,"法律專業");
sheet.addCell(falv);
Label zhong = new Label(2,2,"中");
sheet.addCell(zhong);
Label ligong = new Label(0,3,"北京理工大學");
sheet.addCell(ligong);
Label hangkong = new Label(1,3,"航空專業");
sheet.addCell(hangkong);
Label di = new Label(2,3,"低");
sheet.addCell(di);
//把創建的內容寫入到輸出流中,并關閉輸出流
workbook.write();
workbook.close();
os.close();
}
}
SimpleExcelWrite.jsp
%@ page language="java" import="java.util.*" pageEncoding="gb2312"%
%@ page import="java.io.*" %
%@ page import="beans.excel.*" %
%
String fname = "學校競爭力情況";
OutputStream os = response.getOutputStream();//取得輸出流
response.reset();//清空輸出流
//下面是對中文文件名的處理
response.setCharacterEncoding("UTF-8");//設置相應內容的編碼格式
fname = java.net.URLEncoder.encode(fname,"UTF-8");
response.setHeader("Content-Disposition","attachment;filename="+new String(fname.getBytes("UTF-8"),"GBK")+".xls");
response.setContentType("application/msexcel");//定義輸出類型
SimpleExcelWrite sw = new SimpleExcelWrite();
sw.createExcel(os);
%
html
head
title/title
/head
body
/body
/html
第一個不就是一對多嗎? 我給你看看已訂單號進行關聯
訂單號,訂單日期,用戶姓名,送貨地址
1 2015/9/1 kill 北京
訂單項id,訂單號,商品名稱,商品價格,商品數量)
123 1 泡面 10 100
223 1 純凈水 11 111
省,市,區,街道 訂單號
1 1 1 1 1
2 2 2 2 1
strust2 (我沒有用過不過我一般是這樣做的)
直接用用后臺進行校驗
若用java實現,則用java創建一個定時任務,每隔段時間,更新下那表,發現超過二十分鐘的,更新狀態值,
如果是在數據庫的話,可以創建個定時任務
package cn.test.logan.day04;
import java.util.ArrayList;
/**
* 訂單類
* 包含:訂單ID、訂單所屬用戶、訂單所包含的商品、訂單總金額、訂單應付金額
* 500-1000 ------- 8.5折
* 1000-1500 ------- 8折
* 1500-2000 ------- 7折
* 2000以上 ------- 6.5折
* 如果是會員,那么可以基于以上折扣繼續折扣
* 一般會員:9.5折
* 中級會員:9折
* 高級會員:8折
* @author QIN
*
*/
public class Order {undefined
// 訂單ID
public String ordId;
// 訂單所屬用戶
public User user;
// 訂單所包含的商品(多個商品,使用ArrayList)
public ArrayList pds;
// 訂單總金額
public float ordAllAmt;
// 訂單應付金額
public float payAmt;
// 計算總金額的方法
public void setAllAmt() {undefined
float sum = 0;
for(int i=0;i
sum +=this.pds.get(i).price * this.pds.get(i).number;
}
this.ordAllAmt = sum;
}
// 計算實付金額
public void setPayAmt() {undefined
float tmp = this.ordAllAmt;
// 根據總金額進行折扣
if(this.ordAllAmt = 500 this.ordAllAmt
tmp = this.ordAllAmt * 0.85f;
}
if(this.ordAllAmt = 1000 this.ordAllAmt
tmp = this.ordAllAmt * 0.8f;
}
if(this.ordAllAmt = 1500 this.ordAllAmt
tmp = this.ordAllAmt * 0.7f;
}
if(this.ordAllAmt = 2000) {undefined
tmp = this.ordAllAmt * 0.65f;
}
// 根據會員等級折扣
if(user.CustLevel.equals("一般會員")) {undefined
tmp = tmp * 0.95f;
}
if(user.CustLevel.equals("中級會員")) {undefined
tmp = tmp * 0.9f;
}
if(user.CustLevel.equals("高級會員")) {undefined
tmp = tmp * 0.8f;
}
//計算結果賦值給對象上的payAmt變量
this.payAmt = tmp;
}
}
參考資料來源:百度貼吧CSDN博主「公子京」
新聞標題:java代碼編寫訂單狀態,java代碼編寫訂單狀態不正確
本文地址:http://vcdvsql.cn/article44/hssgee.html
成都網站建設公司_創新互聯,為您提供微信公眾號、品牌網站建設、網站營銷、網站改版、網站制作、網站導航
聲明:本網站發布的內容(圖片、視頻和文字)以用戶投稿、用戶轉載內容為主,如果涉及侵權請盡快告知,我們將會在第一時間刪除。文章觀點不代表本網站立場,如需處理請聯系客服。電話:028-86922220;郵箱:631063699@qq.com。內容未經允許不得轉載,或轉載時需注明來源: 創新互聯