JavaWeb如何将后台数据传递到前台页面HttpServletResponse和HttpServletRequest

继续总结:Java经过Action后,怎么将action中返回的数据写到前台去

先了解下:HttpServletResponse对象

(1).Web服务器收到一个http请求,会针对每个请求创建一个HttpServletRequest和HttpServletResponse对象,向客户端发送数据找HttpServletResponse,从客户端取数据找HttpServletRequest;

(2).HttpServletResponse对象可以向客户端发送三种类型的数据:a.响应头b.状态码c.数据

(3).自己去看HttpServletResponse的API

(4).rsponse向前台返回数据:

a.使用OutputStream向客户端写入中文:

    response.setHeader("Content-type","text/html;charset=UTF-8");//向浏览器发送一个响应头,设置浏览器的解码方式为UTF-8
    String data = "中国";
    OutputStream stream = response.getOutputStream();
    stream.write(data.getBytes("UTF-8"));

b.使用Writer向客户端写入中文:

   response.setCharacterEncoding("UTF_8");//设置Response的编码方式为UTF-8
    response.setHeader("Content-type","text/html;charset=UTF-8");//向浏览器发送一个响应头,设置浏览器的解码方式为UTF-8,其实设置了本句,也默认设置了Response的编码方式为UTF-8,但是开发中最好两句结合起来使用
    //response.setContentType("text/html;charset=UTF-8");同上句代码作用一样
    PrintWriter writer = response.getWriter();
    writer.write("中国");

看看企业一般怎么用:不管怎么用,无非就是封装成方法,向前台返回数据

Action:

public void searchModelIsUsed() {
		<strong>HttpServletRequest req = ServletActionContext.getRequest();</strong>
		boolean result1 = this.voucherTypeService.queryProductionMode();
		if(result1==false){
			//非生产模式则可修改模板
			String result="is_PRODUCTION_MODE";
			this.<strong>actionWrite</strong>("{success:'true',info:'" + result + "'}");
		}else{
			String vmId = req.getParameter("vmId");
			boolean result = this.voucherTypeService.checkVoucherModelUsed(vmId);
			this.actionWrite("{success:'true',info:'" + result + "'}");
		}
	}

上面得到结果result,向前台返回显示数据用actionWrite

actionWrite如下:

	public void actionWrite(String result) {
		if(result == null){
			result = "";
		}
		HttpServletResponse resp = ServletActionContext.getResponse();
		resp.setContentType("text/json;charset=UTF-8");
		resp.setHeader("Cache-Control", "no-cache");
		PrintWriter pw = null;
		try {
			pw = resp.getWriter();
			pw.write(result);
		} catch (IOException e) {
			throw new EVoucherException("获取http写入流异常" + e.getMessage());
		} finally {
			if (pw != null) {
				pw.close();
			}
		}
	}

可以看到actionWrite方法就是一个HttpServletResponse设置相关信息后利用PrintWriter向前台写数据

在前台JS中,就是响应response后台传递过来的数据就OK。

callback : function (options,success,response){
	if(success){

		checkSessionOverdue(response.responseText);
		var msg = Ext.JSON.decode(response.responseText);
	var msgInfo = msg.info;
	if(msgInfo == 'true'){
		Ext.Msg.alert("系统提示", "当前模板已存在历史数据,只能修改模板名称跟启用日期!");
		isAddVoucherModel = false;
		refreshAddVoucherModelForm(false);
	}else if(msgInfo=='is_PRODUCTION_MODE'){
		isAddVoucherModel = true;
		refreshAddVoucherModelForm(false);
	}else{
		isAddVoucherModel = true;
		refreshAddVoucherModelForm(false);
	}

	}
}

时间: 2024-12-19 06:09:04

JavaWeb如何将后台数据传递到前台页面HttpServletResponse和HttpServletRequest的相关文章

后台action处理数据传递给前台界面

package com.renmai.util; import java.io.IOException; import javax.servlet.http.HttpServletResponse; public class ResponseUtil { public static void writeGBK(HttpServletResponse response,String content) { response.setContentType("text/html;charset=GBK&

SSM将后台获取的数据转换成json格式传递到前台页面

1.后台从数据库中获取数据,传递到response中 这一步折腾了我一整天,不知道是因为没有传递到response中还是其他的原因,在前台获取的data,使用alert(data)输出的一直为空值或null有两种方式可以实现这一步.一是利用注解@ResponseBody,二是利用PrintWriter.最终我是通过@ResponseBody成功完成了这一步,而不知道为什么利用PrintWriter总是写不成功,具体的原因我后面再研究研究吧.下面来介绍下这两种实现方式: (1)@ResponseB

后台数据赋给前台控件

是首先在后台文件里定义一个变量 public static string str= ""; protected void Page_Load(object sender, EventArgs e) { str="ASP" } 记住一定要定义在Page_Load事件外面,与Page_Load事件同级 然后在前台以TextBox控件为例 <input type="text" value="<%=str%> /> 至此

C# 将后台数据 写到前台脚本中去【控制页面中某些脚本只在 页面第一次加载的时候才去 执行】

protected void Page_Load(object sender, EventArgs e) { if (!Page.IsPostBack) { this.domainBind(); Page.RegisterClientScriptBlock("F1", "<script>var c=1</script>"); } else { Page.RegisterClientScriptBlock("F0", &qu

后台数据传递到页面

router.get '/', (req, res)-> res.render 'setting', { games:games,counts:counts } p class:"fontP",->@games.gameName a href:"javascript:Ongame(#{@games.gameId})", id:"onegame",->"真测试" p ->@counts

java中如何把后台数据推送到页面上 【后续编辑】

https://my.oschina.net/yongqingfan/blog/535749 http://www.blogjava.net/BearRui/archive/2010/05/19/flush_chunk_encoding.html http://www.cnblogs.com/hoojo/p/longPolling_comet_jquery_iframe_ajax.html javaweb 长连接

基于struts2 拦截器ResultType为chain的Action之间数据传递 ——表单页面打开优化

工作流所使用的表单页面使用freemarker设计,在发起或审批流程页面将表单作为一个iframe嵌入其中,实现如下: <iframe id="doJobframe" name="doJobframe" frameborder="0" scrolling="yes" height="100%" width="100%" style="padding: 0; margin-

关于用bootstrap显示查询的后台数据

PrintWriter pw = response.getWriter(); pw.println(sb); pw.flush(); 由于用bootstrap查询数据,页面需要自身返回bootstrap数据,所以后台forward到了前台页面,前台的页面需要用一个接收页面. 1,页面a 填入需要查询的数据,把页面a的数据封装或者在地址栏encodeURI到页面b; 2,页面b接收到页面a的查询参数,在页面b中写bootstrap表格,url 参数 data数据就是页面a的数据,拿到后台查询后,用

用ajax获取后台数据,返回json数据,怎么在前台使用?

用ajax获取后台数据,返回json数据,怎么在前台使用呢? 后台 C# code ? 1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 if (dataType == "SearchCustomer")                 {                     int ID;                     if (Int32.TryParse(CustomerID, out ID))                     {