【公司动态添加行】前台穿一个json的字符串到后台,并解析

<!doctype html>
<html lang="en">
<head>
<meta charset="UTF-8">
<meta name="Generator" content="EditPlus®">
<meta name="Author" content="">
<meta name="Keywords" content="">
<meta name="Description" content="">
<title>代码自动转换</title>
<link href="css/bootstrap.min.css" rel="stylesheet" type="text/css"/>
<link href="css/base.css" rel="stylesheet" type="text/css"/>
<link href="css/fistIndex.css" rel="stylesheet" type="text/css"/>
</head>
<body>
<div id="header_s">
<ol>
<li><img src="">图片自己定义</li>
<li class="back"><a href="daima.html" >通过类自动生成代码</a></li>
<li class="back"><a href="daima2.html">通过SQL自动生成代码</a></li>
<li class="back"><a href="daima3.html">使用说明</a></li>
</ol>

</div>
<div id="content_s" class="clear">
<h4>表单输入和验证</h4>
<form>
<div id="div_monad">
<tr>
<td>java类包路径</td>
<td><input placeholder="请输入java类包路径" type="text" id="packeDir"/><span id="error1"></span> </td>
<td> <input placeholder="请输入类名" type="text" id="className"/><span id="error2"></span> </td>

</tr><br>
<tr class="clear">
<td><input type="button" value="添加" id="btn_addUpload"></td>
<td><input type="button" value="生成代码" id="btn_creatCode"></td>
<td><input type="button" value="保存" id="btn_save"></td>
</tr><br>
<tr id="table_s">
<th>权限</th>
<th>类型</th>
<th>属性名</th>
<th>主键</th>
<th>备注</th>
</tr>
<div id="div_tab_first" ></div>
</div>
<table id=‘tbody‘ align="center">

</table>
</form>
</div>
<script src="js/jquery-2.1.4.min.js" type="text/javascript"></script>
<script >
$(".back").mousemove(function(){
$(this).attr("style","background-color:#432;");
});
$(".back").mouseout(function(){
$(this).attr("style","");
});

var rLicNoKey = ‘id‘;
/* var uploadControlString = ‘<tr class="even">‘
+ ‘<td align="center"><input id="spCodeFile_{index}" type="text" validators="validators:required,maxLength=10,pattern=regex[数据格式不正确]" regex="^((\-)?\d*(\.)?\d*)$" maxlength="10" name="{spCode}"></input>‘
+ ‘<td align="center"><input id="spNameFile_{index}" type="text" style="width: 95%;" maxlength="60" name="{spName}"></input></td>‘
+ ‘</tr>‘; */
var uploadControlString = ‘<tr><td><select name="spLimit" id="spLimit_{index}"><option value="private">private</option><option value="public">public</option></select></td>‘
+‘<td><select name="spNature" id="spNature_{index}"><option value="String">String</option><option value="int">int</option><option value="char">char</option><option value="byte">byte</option><option value="shot">shot</option><option value="long">long</option><option value="float">float</option><option value="double">double</option><option value="boolean">boolean</option></select></td>+‘
+‘<td><input type="text" id="spAttName_{index}"></td>‘
+‘<td><input id="sppriKey_{index}" type="checkbox"/></td>‘
+‘<td><input type="text" id="spRemark_{index}"></td>‘
+‘<td><a href="#" id="remove_{index}">删除</a></td>‘
+‘</tr>‘;

var uploadGlobalArray = new Array();
var uploadGlobalMap = {};
var rowSelects = {};
var uploadTab = $(‘#div_tab_first‘);
var indexGlobal = 0;
var countGlobal = 0;

addUpload();

function addUpload() {
indexGlobal = indexGlobal + 1;
var t = $(this);
var u = ‘‘ + uploadControlString;
var index = indexGlobal;
//--修改新增控件的名称、ID和题头
u = u.replace(‘{index}‘, index).replace(‘{index}‘, index).replace(‘{index}‘, index).replace(‘{index}‘, index).replace(‘{index}‘, index).replace(‘{index}‘, index);
/* u = u.replace(‘{spName}‘, index);

u = u.replace(‘{spCode}‘, index); */
var $upload = $(u);

// uploadGlobalArray.push($upload);
uploadGlobalMap[index] = $upload;
uploadTab.append($upload);
var ctlUploadNewId = "select_" + index;
$("#" + ctlUploadNewId).html($("#listSample").html());
rowSelects[index] = index;
var id_remove = "#remove_" + index;
// alert(id_remove);
$(id_remove).bind(‘click‘, {
‘index‘: index
}, function (e) {
removeOne(e);
});
countGlobal = countGlobal + 1;
}
function removeUpload() {
if (countGlobal > 0) {
var t = $(this);
// var temp = uploadGlobalArray.pop();
var temp = uploadGlobalMap[indexGlobal];
delete uploadGlobalMap[indexGlobal];
delete rowSelects[indexGlobal];
temp.remove();
countGlobal = countGlobal - 1;
}
}
function removeOne(that) {
var index = that.data.index;
var temp = uploadGlobalMap[index];
// uploadGlobalArray.pop();
delete uploadGlobalMap[index];
delete rowSelects[index];
temp.remove();
countGlobal = countGlobal - 1;
return false;
}
function save() {
/* if (countGlobal <= 0) {
alert("数据输入不完整");
return false;
} else { */
var jsonItemsString = "";
for ( var i in rowSelects) {
var spLimit = $("#spLimit_" + rowSelects[i]).val();
var spNature = $("#spNature_" + i).val(); //
var spAttName = $("#spAttName_" + i).val(); //
var sppriKey = $("#sppriKey_" + i).val(); //
var spRemark = $("#spRemark_" + i).val(); //

if (spNature == "") {
alert("属性名不能为空");
return false;
}
if (spNature != "") { //-- HS编号与品名都未录入的行忽略掉,只保存都录入的行
var tempString = ‘{"spLimit":"‘ + spLimit
+ ‘","spNature":"‘ + spNature + ‘","spAttName":"‘ + spAttName
+ ‘","sppriKey":"‘ + sppriKey + ‘","spRemark":"‘ + spRemark+‘"}‘;
if (jsonItemsString.length > 0){
jsonItemsString = jsonItemsString + "," + tempString;
} else {
jsonItemsString = tempString;
}
}
}
var packeDir=$("#packeDir").val();
var className=$("#className").val();
var nameTotle=‘{"classDir":"‘+packeDir+‘","className":"‘+className+‘"}‘;
if (jsonItemsString.length > 0) { //--判断是否有需要保存的数据
jsonItemsString = "[" + jsonItemsString + "]";
nameTotle = "[" + nameTotle + "]";
//ajax 请求
$.post(‘insert‘, {
‘nameTotle‘:nameTotle,
‘jsonItemsString‘ : jsonItemsString
}, function(data) {
change();
alert(data);
});
} else {
return false;
}

}

$(‘#btn_addUpload‘).bind(‘click‘, addUpload);
$(‘#removeUpload‘).bind(‘click‘, removeUpload);
$(‘#btn_save‘).bind(‘click‘, save);
</script>
</body>
</html>

package com.feiyx.autojcode;

import java.io.File;
import java.io.FileWriter;
import java.io.IOException;
import java.io.PrintWriter;
import java.util.HashMap;
import java.util.List;
import java.util.Map;

import javax.servlet.ServletException;
import javax.servlet.http.HttpServlet;
import javax.servlet.http.HttpServletRequest;
import javax.servlet.http.HttpServletResponse;

import com.feiyx.bean.BigEntity;
import com.feiyx.bean.ClassName;

import freemarker.template.Configuration;
import freemarker.template.DefaultObjectWrapper;
import freemarker.template.Template;
import freemarker.template.TemplateException;

/**
* @author 【狒狒Q:9715234】
* @time 2016-1-27 下午5:41:45
*
* @motto 既然笨到家,就要努力到家...
*
*/
public class FeiTotalManager extends HttpServlet {
private static final long serialVersionUID = 1L;

public void service(HttpServletRequest request,
HttpServletResponse response)
throws ServletException, IOException {
PrintWriter out = response.getWriter();
response.setContentType("text/html;charset=utf-8");

String className = request.getParameter("nameTotle");
List<ClassName> classNameList = JsonUtil.getJavaCollection(
new ClassName(), className);
// ClassName classNam=(ClassName)classNameList.get(0);
System.out.println(className.toString());

String jsonItemsString = request.getParameter("jsonItemsString");
List<BigEntity> bigEntityList = JsonUtil.getJavaCollection(
new BigEntity(), jsonItemsString);
System.out.println(jsonItemsString);

try {
FeiTotalManager.beanTool(bigEntityList,classNameList);
} catch (Exception e) {
e.printStackTrace();
}
int i = 0;
if (i == 1) {
out.print("O(∩_∩)O 提交成功!"+i);
} else {
out.print("o(︶︿︶)o 唉!失败了!");
}
}
/**
*
* @param classes
* @param entryPath
* @param tarPath
* @param templateName
* @throws Exception
*/
public static void createBeanService(List<BigEntity> bigEntity,List<ClassName> className,String templateName) throws Exception{
String cName=className.get(0).getClassName();
String classDir=className.get(0).getClassDir();

/** SRC的目录 **/
String PathSrc=Constants.PATH_PROJECT_SRC;
/**模板的目录**/
String templatePath=Constants.PATH_PROJECT_TEMP;

/** 导出的目标路径 **/

File tarfile=new File(PathSrc,cName+"Service.java");
FileWriter fw = new FileWriter(tarfile); //导出的目录

File file = new File(templatePath); //模板文件路径
// String templateName=cName+"service.java";
String templateEncoding="UTF-8";

Map<String, List> map = new HashMap<String, List>();

map.put("classList", bigEntity);
map.put("className", className);
createJava(file,templateName, templateEncoding, map , fw);
}
/**
*
* @param file
* @param templateName
* @param templateEncoding
* @param root
* @param fw
*/

public static void createJava(File file, String templateName,String templateEncoding,Map<?,?> root ,FileWriter fw) {
try {
Configuration config=new Configuration();

//设置要解析的模板所在的目录,并加载模板文件
config.setDirectoryForTemplateLoading(file);
//设置包装器,并将对象包装为数据模型
config.setObjectWrapper(new DefaultObjectWrapper());
config.setDefaultEncoding(templateEncoding);
//获取模板,并设置编码方式,这个编码必须要与页面中的编码格式一致
Template template=config.getTemplate(templateName,templateEncoding);
template.setEncoding(templateEncoding);

template.process(root, fw);
fw.flush();
fw.close();
} catch (IOException e) {
e.printStackTrace();
}catch (TemplateException e) {
e.printStackTrace();
}

}
/**
*
* @param c
* @param EntryPath
* @param tarPath
* @throws Exception
*/
public static void beanTool(List<BigEntity> list,List<ClassName> className)throws Exception{
createBeanService(list,className,"temp_inface.ftl");
}

}

commons-beanutils-1.7.0.jar
commons-collections-3.1.jar
commons-httpclient-3.0.jar
commons-lang-2.3.jar
commons-logging-1.0.4.jar
ezmorph-1.0.4.jar
freemarker.jar
hibernate-annotations.jar
json-lib-2.4-jdk15.jar
mysql-connector-java-5.1.30-bin.jar
rapid-generator-4.0.jar
servlet-api.jar

需要这些jar包

/**得到javaCoolection
* List<SafePlan> javaCollection = JsonUtil.getJavaCollection(new SafePlan(), s);
* @param clazz
* @param jsons
* @return
*/
public static <T> List<T> getJavaCollection(T clazz, String jsons) {
if(StringUtils.isBlank(jsons))
return null;
List<T> objs = null;
JSONArray jsonArray = (JSONArray) JSONSerializer.toJSON(jsons);
if (jsonArray != null) {
objs = new ArrayList<T>();
List list = (List) JSONSerializer.toJava(jsonArray);
for (Object o : list) {
JSONObject jsonObject = JSONObject.fromObject(o);
T obj = (T) JSONObject.toBean(jsonObject, clazz.getClass());
objs.add(obj);
}
}
return objs;
}

/**
* 转换LIST为 jsonStr
* @param list
* @return
*/
public static String getJavaCollectionJsonStr(List list){
JSONArray jsonArray3 = JSONArray.fromObject( list );
return jsonArray3.toString();
}

public static String getJavaObjectJsonStr(Object list){
JSONObject fromObject = JSONObject.fromObject(list );
return fromObject.toString();
}

时间: 2024-10-09 20:40:18

【公司动态添加行】前台穿一个json的字符串到后台,并解析的相关文章

前台页面中json和字符串相互转化

比如我有两个变量,我要将a转换成字符串,将b转换成JSON对象: var a={"name":"tom","sex":"男","age":"24"} var b='{"name":"Mike","sex":"女","age":"29"}'; 在Firefox,chrom

asp.net MVC 给Controler传一个JSon集合,后台通过List&lt;Model&gt;接收

需求情景 View层经常需要通过Ajax像后台发送一个json对象的集合,但是在后台通过List<Model>无法接收,最后只能通过妥协的方式,在后台获取一个json的字符串,然后通过JsonConvert转为List<Model>.这样比较low. 正确处理方式: 在ajax发送请求的时候,将contentType设置为:application/json,不手动设置的话,会采用默认'application/x-www-form-urlencoded'的类型,所以后台接收不到.

关于json和字符串之间的转换

在最近的工作中,使用到JSON进行数据的传递,特别是从前端传递到后台,前台可以直接采用ajax的data函数,按json格式传递,后台Request即可,但有的时候,需要传递多个参数,后台使用request进行接收.有时传递了几个数值,还好接收.但是如果传递一个json数组,这样后台接受的时候Request多个很麻烦,此时要按照类的格式或者 集合的形式进行传递.例如下面的例子: 前台按类的格式传递JSON对象: var jsonUserInfo = "{\"TUserName\&quo

《项目经验》--通过js获取前台数据向一般处理程序传递Json数据,并解析Json数据,将前台传来的Json数据写入数据库表中

  先看一下我要实现的功能界面:   这个界面的功能在图中已有展现,课程分配(教师教授哪门课程)在之前的页面中已做好.这个页面主要实现的是授课,即给老师教授的课程分配学生.此页面实现功能的步骤已在页面中有所体现,这里不再赘述,此篇文章主要介绍:我是如何通过js从前台获取数据,然后通过ajax技术向后台一般处理程序传递JSON,后台又是如何获取传来的JSON,并对JSON数据转换,然后将转换后的数据写入数据库的! 介绍这些步骤实现前,先说说自己的辛酸:絮叨辛酸,是因为为了实现这个功能,我真的用了很

通过js获取前台数据向一般处理程序传递Json数据,并解析Json数据,将前台传来的Json数据写入数据库表中

摘自:http://blog.csdn.net/mazhaojuan/article/details/8592015 通过js获取前台数据向一般处理程序传递Json数据,并解析Json数据,将前台传来的Json数据写入数据库表中  先看一下我要实现的功能界面:   这个界面的功能在图中已有展现,课程分配(教师教授哪门课程)在之前的页面中已做好.这个页面主要实现的是授课,即给老师教授的课程分配学生.此页面实现功能的步骤已在页面中有所体现,这里不再赘述,此篇文章主要介绍:我是如何通过js从前台获取数

手写一个json格式化 api

最近写的一个东西需要对json字符串进行格式化然后显示在网页上面. 我就想去网上找找有没有这样的api可以直接调用.百度 json api ,搜索结果都是那种只能在网页上进行校验的工具,没有api. 那只有自己去实现一个json 格式化工具. 仔细分析,实现起来并不是很困难,至少思路很清晰. 需要解决的几个问题: 对json的校验:主要是符号的匹配: 格式化预处理:去除键值对之间的空白字符: 格式化:主要是缩进的问题,要符合json通常展示的格式. 解决的办法: 针对A问题: 可以采用栈去匹配符

SpringMVC3.2 解决PO返回前台转成JSON时数据Long精度丢失问题

SpringMVC3.2  解决PO返回前台转成JSON时数据Long精度丢失问题 方案 1.自定义一个杰克逊的json转换类 public class LongToStringAdapter extends ObjectMapper { private static final long serialVersionUID = 4402127997078513582L; public LongToStringAdapter() { super(); SimpleModule simpleModu

动态添加行的方案

在动态添加行的时候(表格操作居多),首先想到的就是克隆上一个tr再进行添加.实践来看,可行性不大,可能每个tr的id.顺序号,或者是其他的属性,都不能动态构造:还有一种方案是用一个div层,把tr包住,隐藏,添加的时候再去读取,事实上也是不可行的.div包裹tr会导致结构混乱.另外动态构造也不行. 正是因为动态添加行不好操作,所以才会有很多js模板引擎应运而生.由于网上有教程了,就不做例子,以下是几篇文章,写得不错,记录下来: 1.jquery-tmpl模板引擎 介绍博客:http://www.

Springmvc+mybatis配置前台页面传递JSON串给后台接收。

前台页面js方法: $(document).ready(function(){ var saveDataAry=[]; var data1={"id":5,"name":"益生元","province":"西藏"}; var data2={"id":6,"name":"好爸爸","province":"拉萨"