js脚本中执行java后台代码方法解析
使用场景:关闭页面弹窗时执行sql语句。
其实js里执行sql语句有多种方式。
方式一:直接在js代码里调用sql语句,原则上不能使用,因为这将sql直接暴露在客户端,安全性极差。
方式二:在js里运用ajax技术,调用后台方法执行sql语句。
方式三:运用dwr框架,其实是对ajax技术进行了封装。
一、首先编写一个dwr.xml文件
); UserInfoManageOpDwr.addUserInfo(String,String,String,String,String,String,String,String,String,String,String,String,String,String,String,String,String,String,String,String,String,String,String,String,Map ); ]]>
二、在web.xml文件里配置servlet
dwr-invoker uk.ltd.getahead.dwr.DWRServlet debug false allowGetForSafariButMakeForgeryEasier true crossDomainSessionSecurity false 1 dwr-invoker /dwr/*
三、写一个普通的JAVA类
packagecn.etcom.jfgl.tel.fee.callType;
importjava.sql.Connection;
importjava.sql.PreparedStatement;
importjava.sql.ResultSet;
importjava.sql.SQLException;
importjava.util.ArrayList;
importjava.util.List;
importjavax.servlet.http.HttpServletRequest;
importorg.json.JSONException;
importorg.json.JSONObject;
importcn.etcom.common.utility.DBUtil;
importcn.etcom.common.utility.RsHandler;
importcn.etcom.common.utility.SqlActuator;
importcn.etcom.common.utility.StringUtil;
/*******************************************************************************
*
*@author刘彦宁2011-08-12
*
*/
//处理呼叫类型的dwr
publicclassCallTypeOpDwr{
/***************************************************************************
*DWR方法,执行存储过程。
*
*/
publicStringupdateSp(){
Stringsql="execPub_Sp_UpdateFieldMemo?";
Connectionconn=DBUtil.getConnection();
PreparedStatementpsmt=null;
try{
psmt=conn.prepareStatement(sql);
psmt.setString(1,"CALL");
booleana=psmt.execute();
DBUtil.close(null,psmt,conn);
conn=DBUtil.getConnection();
psmt=conn.prepareStatement(sql);
psmt.setString(1,"USER");
booleanb=psmt.execute();
System.out.println(a);
System.out.println(b);
System.out.println("关闭弹窗执行存储过程>>"+sql);
}catch(SQLExceptione){
e.printStackTrace();
}finally{
DBUtil.close(null,psmt,conn);
}
returnnull;
}
}
四、写一个JSP页面,主要导入engine.js和相应的java类映射的js文件,然后编写js即可调用
//以下为jsp的引入js文件部分//设置根路径,放在tab.js前 varglbRootPath="<%=basePath%>"; js/lhgdialog/lhgcore.min.js"type="text/javascript"> js/lhgdialog/lhgdialog.js"type="text/javascript">
五、js文件里调用后台代码
varbasePath="";
if(typeof(glbRootPath)!="undefined"){
basePath=glbRootPath;
document.write("<\/script><\/script>");
}
/*
中间省略若干代码
*/
.
.
.
if(typeof(glbRootPath)!="undefined"&&$(this).parent().children().eq(0).text()=="呼叫类型设置"){
console.log("进来了");
DWREngine.setAsync(false);
CallTypeOpDwr.updateSp();
}
以上就是本文的全部内容,希望对大家的学习有所帮助,也希望大家多多支持毛票票。