ajax传数据给后端HttpServletRequest为null

![js
连接成功就是传值得时候后台取不到值一直是null!图片说明

5个回答

我这看不到图片,我之前遇到过得问题是通过post传值的时候请求头写错了。 你参考一下。

哥们,你ajax怎么写的啊

你可以直接通过浏览器访问地址:
http://localhost:8080/test/register?username=abcs&password=123

地址换成你自己的,参数带上就行.这是get方式.

另外如果你是自己练习的话,可以先试试get方式,然后在试试post方式.因为登录注册,一般是用post方式.

ajax 参考:

$.ajax({
    url:"xxxxxxx"
        data:{
           name:'dsdsd',
            password:'sdsdds'
        },
        dataType:"json",
        success:function(data){
           // 假设你返回json
        }


})

你得把ajax请求写出来,排除ajax 请求传值没问题

内容在详细点 贴出的东西没办法做判断

Csdn user default icon
上传中...
上传图片
插入图片
抄袭、复制答案,以达到刷声望分或其他目的的行为,在CSDN问答是严格禁止的,一经发现立刻封号。是时候展现真正的技术了!
其他相关推荐
nginx中,前台使用ajax访问接口,传参数到后端接收为null,如何解决呢

如下是nginx的配置 ``` #前端界面 location / { root D:/ant-design-pro-master/dist; index index.html index.htm; } #后端接口 location ^~ /api/ { proxy_pass http://127.0.0.1:8085; } ``` axios传参代码如下 ``` axios.get(url, { params: { ID: 12345 }, }) .then((response) => { console.log(response); }) .catch((error) => { console.log(error); }); ``` 后台代码如下 ``` @RequestMapping(value = "${adminPath}/login", method = {RequestMethod.GET, RequestMethod.HEAD}) public String login(HttpServletRequest request, HttpServletResponse response, Model model) { Map m = request.getParameterMap(); String id = (String) request.getAttribute("ID"); ```

spring的ajax问题,后台接收HttpServletRequest一直为空

前端的ajax代码: ![图片说明](https://img-ask.csdn.net/upload/201809/25/1537841954_15812.png) 后端代码: ![图片说明](https://img-ask.csdn.net/upload/201809/25/1537841898_153646.png) ajax不管加上contenttype还是不加,后台的HttpServletRequest一直为空 请问各位大佬,这是什么问题?

springmvc后台如何接收ajax传的json格式的数据,以及json数据采用哪种方式传到后台

我现在遇到一个难题,以前,我用ajax传输数据到后台,后台用springmvc接收,成功了,但是,那个时候,我用的ajax的data部分是{"dcCode":dcCode,"itemNo":itemNo...},这样,我是一个参数,一个参数输入的,虽然慢,但是,还是成功地传输了。现在,我遇到的问题是,很多的参数,需要用遍历的方法来传参,我用jsonstr拼接json字符串的方法,拼出了以下的json格式,{"dcCode":"22","itemNo":"3456",...,"sectionName":"食品课"},....,可能有几百条这样的{}, 然后,我创建了一个数组var values=new Array, 用push把这些jsonstr都放进去,最后,我用ajax的dataType:json,post方法把这些数据传到后台,可是,后台是springmvc,@RequestBody(value="/save",method="post"), 可是,当我用String[] values来接收传过来的json参数的时候,却总是null,不知道到底是怎么回事儿,请教大家,都是用什么样的方法来处理这样传输多条json数据到后台的?如果我的思路是对的,能否把这个代码正确的告诉我?如果有更好的方法,请回答。非常感谢。 为了更好的说明问题,我把代码贴出来,如下 ``` function submit(){ debugger; var n=$("#countnumber").text(); var i=0; for(var a=0;a<n;a++){ var saveData=new Array(); var arr1=$('.item p').find('input:text'); var arr2=$('.item p').find('input:checkbox'); for(i=0;i<arr1.length;i++){ saveData.push((arr1).eq(i).val()); }; for(var j=0;j<arr2.length;j++){ saveData.push((arr2).eq(j).val()); }; }; function User(userId,userName,userPwd,memo,addDate,modifyDate,addUserId){ this.userId=saveData[1]; this.userName=saveData[2]; this.userPwd=saveData[3]; this.memo=saveData[4]; this.addDate=saveData[5]; this.modifyDate=saveData[6]; this.addUserId=saveData[7]; }; var user=new User(); var users=new Array(); users.push(user); $.ajax({ type: "post",//数据发送的方式(post 或者 get) url: "insert.do",//要发送的后台地址 data: {"user":JSON.stringify(users)}, dataType: "text",//后台处理后返回的数据格式 success:function (data){ alert(jQuery.parseJSON(data).msg); } }); } ``` 以上是前台的,接下去是后台的 ``` @ResponseBody @RequestMapping(value = "/insert.do", method = RequestMethod.POST) public Map insertUsers(HttpServletRequest request, @RequestBody String users) throws Exception{ users=URLDecoder.decode(users, "utf-8"); ObjectMapper mapper = new ObjectMapper(); //这里用了jackson,自己看看代码,很简洁的 JavaType javaType=mapper.getTypeFactory().constructParametricType(List.class,User.class); List<User> list = mapper.readValue(users, javaType); String msg=userService.insertUsers(list); Map map = new HashMap(); map.put("msg", msg); return map; } ``` 然后,后台的效果截图如下 ![图片说明](https://img-ask.csdn.net/upload/201612/18/1482061394_446729.png) 传到后台的Controller的,数据显示如下 ![图片说明](https://img-ask.csdn.net/upload/201612/18/1482061427_169271.png) 然后,进一步调试,出现错误如下 ![图片说明](https://img-ask.csdn.net/upload/201612/18/1482061332_952640.png) 请问,这个错误到底是什么原因造成的。是500错误。请高手帮助啊!

HTML 通过JSON传数据到后台

``` $(function(){ $('#confirm').click(function(){ var password=$('#password').val(); var re_password=$('#re_password').val(); if(password.length<=0){ alert("密码不能为空"); }else if(password!=re_password){ alert("两次密码不一致") } var datas ={"password":password}; console.log("datas"+datas.password); $.ajax({ url:'/settingpassword.xhtml', type:'post', contentType: "application/json;charset=utf-8", data:datas, error:function(data){ alert(data.password); } }) }) }) ajax date 为空 ``` ``` @RequestMapping("/settingpassword.xhtml") public void settingpassword(@RequestParam("password") String password,HttpServletRequest request){ Integer er=null; JSONArray jsonArray=JSONArray.fromObject(password); System.out.println( " 参数 ---- "+ jsonArray); Iterator<Object> it = jsonArray.iterator(); while(it.hasNext()){ JSONObject obj = (JSONObject)it.next(); System.out.println("password:"+obj.get("password")); er=(Integer) obj.get("agentHouseID"); } System.out.println("你好"); } 后端 ```

使用ajax向后台传值问题

前台 ``` $.ajax({ type : "post", url : "<%=request.getContextPath()%>/linzuosave.do", data : { ID : $("#ID").val(), SO_ID : $("#SO_ID").val(), BAI_NAME : $("#BAI_NAME").val(), BAI_PHONE : $("#BAI_PHONE").val(), BAI_MOBILE : $("#BAI_MOBILE").val(), BUS_TABLEID : $("#BUS_TABLEID").val(), BAI_TYPE : $("#BAI_TYPE").val(), }, dataType : "json", //contentType : "application/json;charset=UTF-8",//json格式必须加 success : function(data) { alert("success"); }, error : function(data) { alert("false"); }, }); ``` 后台 ``` @RequestMapping("/linzuosave.do") public String linzuosave(HttpServletRequest request, HttpServletResponse response) throws IOException { System.out.println("linzuosave"); AccountInfo accountInfo=new AccountInfo(); String str=""; try { accountInfo = (AccountInfo) GetJsonUtil.setObjectValue(request, accountInfo); daolinzuo.save(accountInfo); } catch (Exception e) { e.printStackTrace(); str="false"; } str="success"; return str; } ``` 后台传回来老是会调用到false ,除非返回的是return null ,用过Jasonobject也是一样,但是其中的插入数据库语句代码可以正确执行

ajax可不可以对后台用PUT方式传送文件,后台通过restful的PUT方法接收?

@RequestMapping(value = "User", method = RequestMethod.PUT) @ResponseBody public String update(HttpServletRequest request, HttpServletResponse response, MultipartFile file) throws UnsupportedEncodingException { System.out.println(file.getName()); return null; } //传送文件时总会报错,不知道AJAX要怎么写,希望建议详细点

利用ajax获得后台传过来的json,前端无法解析,对前端不是很深入,求指导

这是servlet: package com.kj.servlet; import java.io.IOException; import java.util.ArrayList; import java.util.List; import javax.servlet.ServletException; import javax.servlet.http.HttpServlet; import javax.servlet.http.HttpServletRequest; import javax.servlet.http.HttpServletResponse; import javax.servlet.http.HttpSession; import net.sf.json.JSONArray; import com.kj.entity.User; import com.kj.service.IUserService; import com.kj.service.impl.UserServiceImpl; public class MainPageServlet extends HttpServlet{ private static final long serialVersionUID = 1L; @Override protected void doGet(HttpServletRequest req, HttpServletResponse resp) throws ServletException, IOException { HttpSession session = req.getSession(); IUserService service = new UserServiceImpl(); String user_id = req.getParameter("user"); //可通过传参实现当前页面第一层节点的转换 if(user_id == null){ //若无参数,使用当前登陆用户 user_id = session.getAttribute("user").toString(); } //当前主页第一节点的user User current_user = service.getUserMessageByid(user_id); List<User> sonUsers = service.getSonUser(current_user.getLeft_num(), current_user.getRight_num(), current_user.getUser_level()); List<User> thrid_user =new ArrayList<User>();; int i = 0; for(User user:sonUsers){ if(user.getUser_level() == current_user.getUser_level()+1){ //展示第二层级 switch(i){ case 0 : req.setAttribute("user_1", user); break; case 1 : req.setAttribute("user_2", user); break; default : req.setAttribute("user_3", user); break; } i++; }else{ thrid_user.add(user); } } //想将下面的array到前端,list转换为json没问题 JSONArray array = JSONArray.fromObject(thrid_user); resp.getWriter().write(array.toString()); req.setAttribute("current_user", current_user); req.getRequestDispatcher("main.jsp").forward(req, resp); } @Override protected void doPost(HttpServletRequest req, HttpServletResponse resp) throws ServletException, IOException { doGet(req, resp); } } 这是js: $(function(){ $.ajax({ url:"main.do", type:"GET", success:function(msg){ var user = eval("("+msg+")"); alert(user.toString()); }, error:function(er){ console.log(er); } }); }) 这样写页面报错:Uncaught SyntaxError: Unexpected token < 。。。

AJAX 响应丢失 后台代码运行完毕,前台没反应 在线等

又一个ajax请求 前台发送请求,后台代码全部运行完了,前台没反应,还在等, 过几分钟之后走error方法, 报504超时 这个ajax的后台请求, 有两种情况, 根据参数,有一种是1秒钟就完事的, 这样的情况下, 前台正常响应, 但是另一种情况下, 需要1分钟才能运行完代码, 这种情况下, 前台就没反应了, 一直在等待响应 但是同样的代码, 在我本地测试都好用, 在另一个服务器也好用, 但是在第三台服务器就不能用,每次都504 这台服务器用的nginx连接,但是nginx的超时我也设置了 上代码 function doRank(isAsync,isRank){ if (isRank != false) { isRank = true; } //加载评级信息 var baseId = $("#baseId").val(); var doRankUrl = "<%=path%>/domesticEntry.gl?method=getRatings&baseId="+baseId+"&isRank="+isRank; doRankAjax = $.ajax({ async: isAsync, type: "post",//请求类型 url: doRankUrl, dataType: "json", //返回的数据类型 success:function(result,status){ var systemRankHtml = result.domesticRating.systemRatingLevel; //一堆代码 $('#waitDoRank').modal('hide'); }, error:function(){ if (isStop) { isStop = false; doRank(false,false); //调用此方法 } else { showMsgForLoad("failure", "系统评级信息"); } $('#waitDoRank').modal('hide'); } }); } 后台代码 public ModelAndView getRatings(HttpServletRequest request, HttpServletResponse response) throws Exception { System.out.println("DRInfoEnteringAction.getRatings()-------------"); try { //一大堆代码 response.setCharacterEncoding("UTF-8"); response.getWriter().write(json.toString()); response.getWriter().flush(); response.getWriter().close(); }catch (Exception e) { e.printStackTrace(); throw e; } return null; }

ajax登录验证,data返回值

$.ajax({ // 请求发送方式 type: 'post', // 验证文件 url: 'login/login', // 用户输入的帐号密码 data: {'adminname': $("#adminname").val(), 'password': $("#password").val()}, // 异步,不写默认为True async: true, //请求成功后的回调 success: function(data){ if (data){ alert(data); alert('登录成功') }else{ alert('帐号或密码错误'); } }, error: function(){ alert('服务端异常'); } if (data)里的data,后台怎么传值给data来判断账号霍迷码是否错误?网上说用0或 1来判断,那后台怎么把0或1传到 data里? 我后台是这样的 /** * 登录方法验证 * */ @RequestMapping("/login") public String login(HttpServletRequest request,HttpServletResponse response,Model model){ //从前台获得输入的账号密码 String user = request.getParameter("adminname"); String psw = request.getParameter("password"); //先判断前台传来的账号是否为空 if(user == null || user==""){ //前台提示 model.addAttribute("msg", "账号为空"); //返回登录界面 return "products/login"; } //通过adminname查询整条数据 admin admin = adminMapper.getAdminByName(user); //判断数据库里是否有这条数据 if(admin==null || "".equals(admin)){ model.addAttribute("msg", "账号或密码错误"); return "products/login"; } //判断账户adminname有没有 if("".equals(admin.getAdminname())){ model.addAttribute("msg", "账号或密码错误"); return "products/login"; } //判断密码password是否存在 if(admin.getPassword()== null){ model.addAttribute("msg", "账号或密码错误"); return "products/login"; } //判断查询到的密码是否与数据库相对应的密码相同 if(!admin.getPassword().equals(psw)){ model.addAttribute("msg", "账号或密码错误"); return "products/index"; } model.addAttribute(user); //验证若都通过则跳到管业页面 return "zhuye"; }

ajax后台代码重复执行

自己写个小程序,遇到个奇葩问题,在点击按钮发送ajax请求查询数据的时候,数据能正常显示,但是在火狐控制台有报错,报错原因是说语法错误,ajax返回内容为 "请求参数不正确!" 这句话是我在Controller层返回的.如果参数缺失才会提示这个.但是我检查后发现并不是参数缺失,而且请求被重复提交,第二次提交参数都丢失了,有点像被重定向了. 第一次数据有正常返回在页面显示,但是不知道为什么会又提交一次,并且网络请求里面只有一次请求!!! ![图片说明](https://img-ask.csdn.net/upload/201510/26/1445872837_367347.png) ![图片说明](https://img-ask.csdn.net/upload/201510/26/1445872910_705246.png) ![图片说明](https://img-ask.csdn.net/upload/201510/26/1445873454_929399.png) ![图片说明](https://img-ask.csdn.net/upload/201510/26/1445873561_584010.png) **js代码如下,触发是查询按钮的点击事件:** js代码检查过不可能重复执行; ``` function getData(startDate,endDate){ var rows=[]; $.ajax({ url:"queryAllUser.do", type:"POST", async:false, data:{'startDate':startDate,'endDate':endDate}, dataType:"json", success:function(data, textStatus){ for(var i=0;i<data.length;i++){ rows.push({ userId: "<a href=''>"+data[i].userId+"</a>", userName: data[i].userName, id: data[i].id, sex: data[i].sex, birthday: data[i].birthday, dateCreated: data[i].dateCreated, }); } } }); var tbodyHtml=""; for(var i=0;i<rows.length;i++){ tbodyHtml+= "<tr>"+ "<td>"+rows[i].userId+"</td>"+ "<td>"+rows[i].userName+"</td>"+ "<td>"+rows[i].id+"</td>"+ "<td>"+rows[i].sex+"</td>"+ "<td>"+rows[i].birthday+"</td>"+ "<td>"+rows[i].dateCreated+"</td>"+ "<td><a class='btn' data-trigger='confirm' href='#'><i class='icon-edit icon-large'></i> Update</a>&nbsp;"+ "<a class='btn' href='#'><i class='icon-trash icon-large'></i> Delete</a></td>"+ "</tr>" } if(rows.length==0){ tbodyHtml+= "<td colspan='7' class='active' style='text-align: center;'>没有指定时间段的数据!</td>" } $("#dataBody").html(tbodyHtml); } ``` **Controller层代码:** ``` @RequestMapping("/queryAllUser.do") public void queryAllUser(HttpServletRequest request ,HttpServletResponse response){ List allUserList; try { PrintWriter out = null; if(!checkParam(request, startDate)){ response.setCharacterEncoding(CommonStr.RETURN_CHARACTERENCODING ); out = response.getWriter(); out.write(CommonStr.CHECK_PARAM_ILLEGAL);//请求参数不合法! }else{ out = response.getWriter(); allUserList=userManagementService.queryAllUser(getParameter(request, startDate,endDate)); JSONArray jsonAry=JSONArray.fromObject(allUserList); out.write(jsonAry.toString()); } out.flush(); out.close(); } catch (IOException e) { e.printStackTrace(); } } ```

ajax请求后台下载zip压缩文件问题,后台返回的是流前台不提示下载。附上ajax请求代码合后台代码

前台: $.ajax({ type:"POST", url:"app/downloadProduct", data:{nid:nid,name:name}, dataType:"text", success:function(data){ console.log(data); if(data!=null){ alert("url="+data); window.location.href = data; }else{ alert("资源获取失败!"); } } }); 后台: public static void downloadExportFileByResponse(String downloadFile, HttpServletRequest request, HttpServletResponse response) throws Exception { System.out.println("--------downloadFile---------"+downloadFile); if(downloadFile==null||"".equals(downloadFile)) { throw new Exception("文件名为空,下载文件失败!"); } try { byte[] buffer = new byte[256]; InputStream is = new FileInputStream(downloadFile); try { downloadFile = downloadFile.substring(downloadFile.lastIndexOf(File.separator) + 1); downloadFile = URLEncoder.encode(downloadFile, "UTF-8"); } catch(Exception e) { e.printStackTrace(); } File filename = new File(downloadFile); //response.setContentType("text/plain"); response.addHeader("content-type","application/x-msdownload");//浏览器自己辨别文件类型 response.addHeader("Content-Disposition", "attachment; filename=" + filename.getName()); response.addHeader("Content-Length", String.valueOf(is.available())); int nRead = 0; while((nRead = is.read(buffer)) > 0) response.getOutputStream().write(buffer, 0, nRead); is.close();

vue ajax Context-type 为 application/x-www-form-urlencoded,Java后端HttpServletResponse.setHeader应该怎样设置

#vue ajax代码 ![图片说明](https://img-ask.csdn.net/upload/202004/18/1587209897_723211.png) #浏览器报错 network 接口信息 ![图片说明](https://img-ask.csdn.net/upload/202004/18/1587209951_744551.png) #下面的response.setHeader()怎样设置 ``` public void doFilter(ServletRequest req, ServletResponse res, FilterChain chain) throws IOException, ServletException { HttpServletRequest request = (HttpServletRequest)req; HttpServletResponse response = (HttpServletResponse) res; String originHeader = request.getHeader("Origin"); response.setHeader("Access-Control-Allow-Origin", originHeader); response.setHeader("Access-Control-Allow-Methods", "POST, GET, OPTIONS, DELETE"); response.setHeader("Access-Control-Max-Age", "1"); response.setHeader("Access-Control-Allow-Headers", "Origin, No-Cache, X-Requested-With, If-Modified-Since, Pragma, Last-Modified, " + "Cache-Control, Expires, Content-Type, X-E4M-With,userId,token"); response.setHeader("Access-Control-Allow-Credentials", "true"); response.setHeader("Content-Language", "zh-CN,zh"); response.setHeader("XDomainRequestAllowed","1"); //response.setHeader("Content-Disposition", "form-data"); response.setContentType("application/x-www-form-urlencoded;charset=UTF-8");//本行代码或者上行怎么设置 chain.doFilter(req, res); } ```

jsp ajax获取不到response.getwriter传回的值

下面先贴出的Servlet.java中的部分代码 protected void doPost(HttpServletRequest request, HttpServletResponse response) throws ServletException, IOException { request.setCharacterEncoding("utf-8"); boolean flag = selectUserList(request, response); if(flag){ try { String username = request.getParameter("username"); String password = request.getParameter("password1"); String phone = request.getParameter("phone"); Connection conn = JdbcUtil.getConnection(); String sql = "insert into t_user values(null,'" + username + "','" + password + "','" + phone + "')"; System.out.println(sql); JdbcUtil.executeUpdate(conn, sql); response.getWriter().write("{\"result\":\"成功\"}"); return ; } catch (SQLException e) { // TODO Auto-generated catch block e.printStackTrace(); } } } 然后是jsp文件中ajax的代码 $.ajax({ url:"RegisterServlet", data:{ username:$(".main_username").val(), phone:$(".main_phone").val(), password1:$(".main_password1").val(), password2:$(".main_password2").val() }, type:"post", dataType:"json", success:function(data){ if(data.result == "成功"){ location.href="https://www.baidu.com"; } }, error:function(){ } }); 为什么获取不到传回来的result的值呢?求大神帮忙解答一下 谢谢

cas方面的问题,怎了半天都没有解决

11:10:04.957 DEBUG org.jasig.cas.client.util.CommonUtils 291 safeGetParameter - safeGetParameter called on a POST HttpServletRequest for LogoutRequest. Cannot complete check safely. Reverting to standard behavior for this Parameter这个提示是啥意思?该如和破?

JSp+ajax用户登录验证

[img]http://dl2.iteye.com/upload/attachment/0088/2001/4ee085e5-47e0-3995-ad42-62e4a53cfc2f.png[/img] 用户登陆界面,想要实现输入账号之后离开输入框就验证该账号是否存在,输入角色、账号、密码之后,点击登录,如果正确就跳转到index.jsp,错误不跳转并且在密码输入框下显示提示信息;有一个没输入就提示,信息也是在密码输入框下。 我现在的问题是:若果什么也不输,点击登录,会闪一下,但闪过之后就是重置了页面。输入正确也是闪一下就重置页面.账号验证没问题,就是登录有问题,但是搞不定,大侠们看看吧! login.jsp [code="java"]<form id="form" name="form" method="post" action="" > <table border="0"> <tr> <td align="right">角色类型:</td> <td><select name="role" id="role" onBlur="checkRole(this)"> <option value="0">-请选择角色-</option> <% List<Role> list = new ArrayList<Role>(); RoleDao dao = new RoleDaoImpl(); list = dao.findAllRoles();//调用实现类的查询全部方法 for (int i = 0; i < list.size(); i++) { Role r = list.get(i); %> <option value="<%=r.getR_id()%>"><%=r.getR_name()%></option> <% } %> </select> </td> <td align="left"> &nbsp; <span id="roleSpan"></span> </td> </tr> <tr> <td align="right">账号:</td> <td> <input type="text" name="number" id="number" onblur="checkNumber(this)"> </td> <td width="256" align="left"> &nbsp; <span id="numberSpan"></span> </td> </tr><!-- 当输入名字后离开输入框即调用--> <tr> <td align="right">密码:</td> <td><input type="password" name="pwd" id="pwd" onBlur="checkPsw(this)" > </td> <td align="left"> &nbsp; <span id="pwdSpan"></span> </td> </tr> <tr> <td align="left">&nbsp;<span id="feedback_info"></span></td> </tr> <tr> <td colspan="1"> <input type="submit" value="登录" onclick="checkLogin(this.form)"/> <input type="button" value="注册" onclick="javascript:window.location.href='User/Register.jsp'"></td> </tr> </table> </form>[/code] login.js [code="java"]var xmlHttp; function createXMLHttpRequest() { if (window.XMLHttpRequest) { var xmlHttp = new XMLHttpRequest(); //mozilla浏览器 } else if (window.ActiveXObject) { try { var xmlHttp = new ActiveX0bject("Msxml2.XMLHTTP"); //IE老版本 } catch (e) { } try { var xmlHttp = new ActiveXObject("Microsoft.XMLHTTP"); //IE新版本 } catch (e) { } } if (!xmlHttp) { window.alert("不能创建XMLHttpRequest对象实例"); return false; } else return xmlHttp; ////}///////花括号放错地方 } // 检查账号,给出提示信息 function checkNumber(Number) { var numberSpan = document.getElementById("numberSpan"); if (Number.value == "") { numberSpan.innerHTML = "账号必须填写".fontcolor("red"); return false; } else { xmlHttp = createXMLHttpRequest(); //createXMLHttpRequest申明的是局部变量,这里访问不到xmlHttp,要给xmlHttp变量赋值才行 var url="servlet/CheckNumberServlet?number="+Number.value+"&LoginTime="+new Date().getTime(); url = encodeURI(url); //转换码后再传输 xmlHttp.open("GET",url,true);//加时间戳防止IE缓存 //xmlhttp.setRequestHeader( "Content-Type", "text/html;charset=UTF-8" ); xmlHttp.onreadystatechange = handleStateChange1; xmlHttp.send(null); return true; } } function handleStateChange1() { var numberSpan = document.getElementById("numberSpan"); if (xmlHttp.readyState == 4) { if (xmlHttp.status == 200) { // alert("来自服务器的响应:"+xmlHttp.responseText); if (xmlHttp.responseText == 'true') {///////responseText是字符串,不能和boolean变量直接比较 // alert("存在"); numberSpan.innerHTML = "<img src='Img/g.gif'>"; document.getElementById("feedback_info").innerHTML=""; return true; } else if (xmlHttp.responseText == 'false') {///////responseText是字符串,不能和boolean变量直接比较 // alert("不存在"); numberSpan.innerHTML = "账号不存在".fontcolor("red"); return false; } } else alert("服务器端错误"); } } // 检查密码,给出提示信息 function checkPsw(pswNode) { var spanNode1 = document.getElementById("pswSpan"); var Role= document.getElementById("role"); var Number= document.getElementById("number"); if (pswNode.value == "") { spanNode1.innerHTML = "密码必须填写".fontcolor("red"); return false; } else { pwdSpan.innerHTML = "<img src='Img/g.gif'>"; document.getElementById("feedback_info").innerHTML=""; return true; } } // 检查是否选中角色 function checkRole(selNode) { var index = selNode.selectedIndex;// 获得选中下标 var spanNode1 = document.getElementById("roleSpan"); if (index <= 0) { spanNode1.innerHTML = "必须选择角色".fontcolor("red"); return false; } else { spanNode1.innerHTML = "<img src='Img/g.gif'>"; document.getElementById("feedback_info").innerHTML=""; return true; } } // 检查表单 function checkLogin(o) { var Role=o.role; var Number= o.number; var Pwd= o.pwd; if(checkNumber(Number)&&checkPsw(Psw) &&checkRole(Role)) { xmlHttp = createXMLHttpRequest(); //createXMLHttpRequest申明的是局部变量,这里访问不到xmlHttp,要给xmlHttp变量赋值才行 var url="servlet/CheckLoginServlet?number="+Number.value+"&role="+Role.value+"&pwd="+Pwd.value+"&LoginTime="+new Date().getTime(); url = encodeURI(url); //转换码后再传输 xmlHttp.open("GET",url,true);//加时间戳防止IE缓存 //xmlhttp.setRequestHeader( "Content-Type", "text/html;charset=UTF-8" ); xmlHttp.onreadystatechange = handleStateChange2; xmlHttp.send(null); return true; } else{ document.getElementById("feedback_info").innerHTML="请填写每一项".fontcolor("red"); return false; } } function handleStateChange2() { if (xmlHttp.readyState == 4) { if (xmlHttp.status == 200) { //alert("来自服务器的响应:" + xmlHttp.responseText); if(xmlHttp.responseText == '0'){ document.getElementById("feedback_info").innerHTML="账号与密码不匹配".fontcolor("red"); return false; } else if(xmlHttp.responseText == '1'){ document.getElementById("feedback_info").innerHTML=""; window.location.href="index.jsp"; return true; } } else alert("服务器端错误"); } }[/code] chuckLoginservlet [code="java"]public void doGet(HttpServletRequest request, HttpServletResponse response) throws ServletException, IOException { response.setContentType("text/html"); doPost(request, response);// 调用doPost方法 } public void doPost(HttpServletRequest request, HttpServletResponse response) throws ServletException, IOException { request.setCharacterEncoding("utf-8"); response.setContentType("text/html;charset=UTF-8"); String number=""; try { number = new String(request.getParameter("number").getBytes( "ISO-8859-1"), "UTF-8"); } catch (Exception e1) { System.out.println("number为空"); } String role="0"; int rID=0; try { role = new String(request.getParameter("role").getBytes( "ISO-8859-1"), "UTF-8"); rID=Integer.parseInt(role);//把获得的role的值转成整型 } catch (Exception e1) { System.out.println(request.getParameter("role")+"******role"); } String pwd=""; try { pwd = new String(request.getParameter("pwd").getBytes( "ISO-8859-1"), "UTF-8"); } catch (Exception e) { System.out.println(request.getParameter("pwd")+"****pwd"); } // String txt = new String(number.getBytes("ISO-8859-1"), "UTF-8"); // System.out.println(txt+"********"); PrintWriter out = response.getWriter(); User u = new User(); UserDao ud = new UserDaoImpl(); u = ud.findUserByNumber(number);//通过账号找到用户对象 if (u != null) {// 找到该用户 int u_id = u.getU_id();// 获得该用户的ID UserRole ur = new UserRole(); UserRoleDao urd = new UserRoleDaoImpl(); ur = urd.findUserRoleByUserId(u_id);// 找到中间表UserRole的记录 int r_id = ur.getRole().getR_id();// 由Userrole表找到Role表的相对应角色名称 if (r_id==rID && u.getU_password().equals(pwd))// 如果数据中的角色和密码与之对应 { out.write("1");//1表示验证通过 } else { out.write("0");//0表示密码与账号不匹配 } } out.flush(); out.close(); }[/code]

Ajax 网页出现 ReferenceError: register is not defined

前端: ``` <%@ page contentType="text/html;charset=UTF-8" language="java" %> <html> <head> <title>$Title$</title> </head> <script type="javascript" src="js/jquery-3.4.1.min.js"/> <script> function register(){ var $phoneNum = $("#phoneNum").val(); $.ajax({ url:"PhoneNumServlet", data:"phoneNum="+$phoneNum, success:function (result, testStatus) { if(result=="true"){ alert("该号码已存在!"); }else{ alert("注册成功!"); } }, error:function (xhr, errorMessage, e) { alert("系统异常!"); } }) } </script> <body> 号码:<input id="phoneNum" /><br/> <input type="button" value="注册" onclick="register()" /> </body> </html> ``` 后端: ``` @WebServlet(name = "PhoneNumServlet") public class PhoneNumServlet extends HttpServlet { protected void doPost(HttpServletRequest request, HttpServletResponse response) throws ServletException, IOException { request.setCharacterEncoding("utf-8"); response.setCharacterEncoding("utf-8"); response.setContentType("text/html;charset=UTF-8"); String phoneNum = request.getParameter("phoneNum"); PrintWriter out = response.getWriter(); if("18888888888".equals(phoneNum)){ out.write("true"); }else{ out.write("false"); } out.close(); } protected void doGet(HttpServletRequest request, HttpServletResponse response) throws ServletException, IOException { doPost(request,response); } } ``` error:![图片说明](https://img-ask.csdn.net/upload/201906/10/1560175399_800815.png)

过滤器过滤特殊字符无法获取到参数

代码如下: ``` $.ajax({ url: url, type: 'post', data: o, cache: false, success: function (text) { console.dir(text); CloseWindow("save"); }, error: function (jqXHR, textStatus, errorThrown) { alert(jqXHR.responseText); CloseWindow(); } }); ``` 我使用ajax方式提交,post提交方式,手动封装data。 后端接收如下: ``` @At("/updateProductCfg") public ExecuteState updateProductCfg(@Param("..") CmsLoanProduct param,HttpSession session) { System.out.print(Json.toJson(param)); UserObject user=(UserObject)session.getAttribute("userObject"); param.setUsrModify(user.getUserId()); param.setOrgModify(user.getUserOrgName()); param.setDatModify(new Timestamp(System.currentTimeMillis())); ExecuteState state = productCfgManagerBiz.updateProductCfg(param); return state; } ``` 现在如果在param参数中有特殊字符,那么我将定义 web.xml,代码如下 ``` <filter> <filter-name>XssFilter</filter-name> <filter-class>com.ifs.frame.filter.XssFilter</filter-class> </filter> <filter-mapping> <filter-name>XssFilter</filter-name> <url-pattern>/*</url-pattern> </filter-mapping> ``` 拦截器代码 ``` public class XssFilter implements Filter { FilterConfig filterConfig = null; public void doFilter(ServletRequest request, ServletResponse response, FilterChain filterChain) throws IOException, ServletException { XssHttpServletRequestWrapper xssRequest = new XssHttpServletRequestWrapper( (HttpServletRequest) request); filterChain.doFilter(xssRequest, response); } @Override public void init(FilterConfig filterConfig) throws ServletException { this.filterConfig = filterConfig; } @Override public void destroy() { this.filterConfig=null; } } ``` XssHttpServletRequestWrapper代码 ``` public class XssHttpServletRequestWrapper extends HttpServletRequestWrapper { public XssHttpServletRequestWrapper(HttpServletRequest servletRequest) { super(servletRequest); } public String[] getParameterValues(String parameter) { String[] values = super.getParameterValues(parameter); if (values==null) { return null; } int count = values.length; String[] encodedValues = new String[count]; for (int i = 0; i < count; i++) { encodedValues[i] = cleanXSS(values[i]); } return encodedValues; } public String getParameter(String parameter) { String value = super.getParameter(parameter); if (value == null) { return null; } return cleanXSS(value); } public String getHeader(String name) { String value = super.getHeader(name); if (value == null) return null; return cleanXSS(value); } private String cleanXSS(String value) { value = value.replaceAll("&", "&amp;"); value = value.replaceAll("#", "&#35;"); value = value.replaceAll("<", "&lt;").replaceAll(">", "&gt;"); value = value.replaceAll("\"", "&#92;"); value = value.replaceAll("'", "&#39;"); return value; } ``` 现在这些代码我确无法获取到data中的值,也无法转换,各位有什么好的解决方法吗? 以我现在所知道的是参数未封装到HttpServletRequest里面导致的。但我现在无法在来修改源码了,也只有通过写过滤器来想办法

java后端返回的图片url在第二次运行的时候就用不了了?

问题是这样,我使用IDEA创建的spring-boot框架,做了一个接收图片返回url的功能,如果服务端不停止,这个url可以访问到图片。但是,如果把服务端stop and rerun,这个url就访问不到图片了。原因我也搞明白了,是因为spring-boot内嵌tomcat,每次运行都会新建一个tomcat-docbase文件夹,所有资源都是放在这里面的。上一次上传的图片在上一次的docbase里面,所以这次运行就访问不到上一次的。但是,我虽然知道了是这样造成的,应该怎么解决呢? 附上代码: ```@RequestMapping("upload") public String upload(HttpServletRequest request, HttpServletResponse response, @RequestParam(value = "file", required = false) MultipartFile file) throws IOException { response.setContentType("text/html;charset=utf-8"); /* 设置响应头允许ajax跨域访问 */ response.setHeader("Access-Control-Allow-Origin", "*"); /* 星号表示所有的异域请求都可以接受, */ response.setHeader("Access-Control-Allow-Methods", "GET,POST"); int id=Integer.parseInt(request.getParameter("uid")); String name=request.getParameter("name"); String title=request.getParameter("title"); System.out.println("执行upload"); request.setCharacterEncoding("UTF-8"); System.out.println("执行图片上传"); String user = request.getParameter("user"); System.out.println("user:"+user); if(!file.isEmpty()) { System.out.println("成功获取照片"); String fileName = file.getOriginalFilename(); String path = null; String type = null; type = fileName.indexOf(".") != -1 ? fileName.substring(fileName.lastIndexOf(".") + 1, fileName.length()) : null; System.out.println("图片初始名称为:" + fileName + " 类型为:" + type); if (type != null) { if ("GIF".equals(type.toUpperCase())||"PNG".equals(type.toUpperCase())||"JPG".equals(type.toUpperCase())) { // 项目在容器中实际发布运行的根路径 String realPath = request.getSession().getServletContext().getRealPath("/"); // 自定义的文件名称 String trueFileName = String.valueOf(System.currentTimeMillis()) + fileName; // 设置存放图片文件的路径 path=realPath+request.getContextPath()+"/"+id+name+title+"articleimages"; //path=realPath+request.getContextPath()+"/"+"articleimages"; File myPath = new File( path ); if ( !myPath.exists()){//若此目录不存在,则创建之 myPath.mkdir(); System.out.println("创建文件夹路径为:"+ path); } String imagepath = path+"/" + trueFileName; System.out.println("存放图片文件的路径:" + imagepath); file.transferTo(new File(imagepath)); System.out.println("文件成功上传到指定目录下"); String url = getTomcatUrl(); String res=url+"/"+id+name+title+"articleimages/"+trueFileName; //String res=url+path+"/"+trueFileName; System.out.println(res); return res; }else { System.out.println("不是我们想要的文件类型,请按要求重新上传"); return "error"; } }else { System.out.println("文件类型为空"); return "error"; } }else { System.out.println("没有找到相对应的文件"); return "error"; } } //获取tomcat项目路径 public static String getTomcatUrl() { HttpServletRequest request = ((ServletRequestAttributes) RequestContextHolder.getRequestAttributes()).getRequest(); String basePath = request.getScheme() + "://" + request.getServerName() + ":" + request.getServerPort() + "/"; return basePath; } ```

request.getParameter后台取不到值

下边的是form代码 <form name="login_form" role="form" action="user?action=login" method="POST" onsubmit="return isValidate(login_form)"> <fieldset> <div id="legend"> <legend class="caption">登录</legend> </div> <div class="form-group"> <label for="username">用户名</label> <input type="text" class="form-control " name="username" id="username" placeholder="Enter email"> </div> <div class="form-group"> <label for="password">密码</label> <input type="password" class="form-control" name="password" id="password" placeholder="Password"> </div> <div class="form-group"> <button type="submit" class="btn btn-success">登录</button> </div> </fieldset> </form> 下边是后台servelet代码 protected void doPost(HttpServletRequest request, HttpServletResponse response) throws ServletException, IOException { response.setContentType("text/html;charset=UTF-8"); response.setCharacterEncoding("UTF-8"); String action = request.getParameter("action"); //这的action就能取到值 if(action.equals("login")){ String username = request.getParameter("username"); String password = request.getParameter("password"); //这的username和password就取不到值,为什么啊? User u = userservice.login(username, password); if(u!=null){ if(u.getIsDelete()==0){ request.getSession().setAttribute("user", u); response.sendRedirect("user?action=index"); }else{ request.getSession().setAttribute("userIsDeleMsg", "该用户已被禁用,无法登录!"); request.getRequestDispatcher("login.jsp").forward(request, response); } }else { request.getSession().setAttribute("msg", "验证失败,请重新输入用户名或密码!"); response.sendRedirect("Login.jsp"); } }else if(action.equals("index")){ //跳转到首页 request.getRequestDispatcher("/index.jsp").forward(request, response); } }

技术大佬:我去,你写的 switch 语句也太老土了吧

昨天早上通过远程的方式 review 了两名新来同事的代码,大部分代码都写得很漂亮,严谨的同时注释也很到位,这令我非常满意。但当我看到他们当中有一个人写的 switch 语句时,还是忍不住破口大骂:“我擦,小王,你丫写的 switch 语句也太老土了吧!” 来看看小王写的代码吧,看完不要骂我装逼啊。 private static String createPlayer(PlayerTypes p...

副业收入是我做程序媛的3倍,工作外的B面人生是怎样的?

提到“程序员”,多数人脑海里首先想到的大约是:为人木讷、薪水超高、工作枯燥…… 然而,当离开工作岗位,撕去层层标签,脱下“程序员”这身外套,有的人生动又有趣,马上展现出了完全不同的A/B面人生! 不论是简单的爱好,还是正经的副业,他们都干得同样出色。偶尔,还能和程序员的特质结合,产生奇妙的“化学反应”。 @Charlotte:平日素颜示人,周末美妆博主 大家都以为程序媛也个个不修边幅,但我们也许...

CSDN:因博主近期注重写专栏文章(已超过150篇),订阅博主专栏人数在突增,近期很有可能提高专栏价格(已订阅的不受影响),提前声明,敬请理解!

CSDN:因博主近期注重写专栏文章(已超过150篇),订阅博主专栏人数在突增,近期很有可能提高专栏价格(已订阅的不受影响),提前声明,敬请理解! 目录 博客声明 大数据了解博主粉丝 博主的粉丝群体画像 粉丝群体性别比例、年龄分布 粉丝群体学历分布、职业分布、行业分布 国内、国外粉丝群体地域分布 博主的近期访问每日增量、粉丝每日增量 博客声明 因近期博主写专栏的文章越来越多,也越来越精细,逐步优化文章。因此,最近一段时间,订阅博主专栏的人数增长也非常快,并且专栏价

我说我不会算法,阿里把我挂了。

不说了,字节跳动也反手把我挂了。

培训班出来的人后来都怎么样了?(二)

接着上回说,培训班学习生涯结束了。后面每天就是无休止的背面试题,不是没有头脑的背,培训公司还是有方法的,现在回想当时背的面试题好像都用上了,也被问到了。回头找找面试题,当时都是打印下来天天看,天天背。 不理解呢也要背,面试造飞机,上班拧螺丝。班里的同学开始四处投简历面试了,很快就有面试成功的,刚开始一个,然后越来越多。不知道是什么原因,尝到胜利果实的童鞋,不满足于自己通过的公司,嫌薪水要少了,选择...

面试了一个 31 岁程序员,让我有所触动,30岁以上的程序员该何去何从?

最近面试了一个31岁8年经验的程序猿,让我有点感慨,大龄程序猿该何去何从。

大三实习生,字节跳动面经分享,已拿Offer

说实话,自己的算法,我一个不会,太难了吧

程序员垃圾简历长什么样?

已经连续五年参加大厂校招、社招的技术面试工作,简历看的不下于万份 这篇文章会用实例告诉你,什么是差的程序员简历! 疫情快要结束了,各个公司也都开始春招了,作为即将红遍大江南北的新晋UP主,那当然要为小伙伴们做点事(手动狗头)。 就在公众号里公开征简历,义务帮大家看,并一一点评。《启舰:春招在即,义务帮大家看看简历吧》 一石激起千层浪,三天收到两百多封简历。 花光了两个星期的所有空闲时...

工作八年,月薪60K,裸辞两个月,投简历投到怀疑人生!

近日,有网友在某职场社交平台吐槽,自己裸辞两个月了,但是找工作却让自己的心态都要崩溃了,全部无果,不是已查看无回音,就是已查看不符合。 “工作八年,两年一跳,裸辞两个月了,之前月薪60K,最近找工作找的心态崩了!所有招聘工具都用了,全部无果,不是已查看无回音,就是已查看不符合。进头条,滴滴之类的大厂很难吗???!!!投简历投的开始怀疑人生了!希望 可以收到大厂offer” 先来看看网...

97年世界黑客编程大赛冠军作品(大小仅为16KB),惊艳世界的编程巨作

这是世界编程大赛第一名作品(97年Mekka ’97 4K Intro比赛)汇编语言所写。 整个文件只有4095个字节, 大小仅仅为16KB! 不仅实现了3D动画的效果!还有一段震撼人心的背景音乐!!! 内容无法以言语形容,实在太强大! 下面是代码,具体操作看最后! @echo off more +1 %~s0|debug e100 33 f6 bf 0 20 b5 10 f3 a5...

不要再到处使用 === 了

我们知道现在的开发人员都使用 === 来代替 ==,为什么呢?我在网上看到的大多数教程都认为,要预测 JavaScript 强制转换是如何工作这太复杂了,因此建议总是使用===。这些都...

什么是a站、b站、c站、d站、e站、f站、g站、h站、i站、j站、k站、l站、m站、n站?00后的世界我不懂!

A站 AcFun弹幕视频网,简称“A站”,成立于2007年6月,取意于Anime Comic Fun,是中国大陆第一家弹幕视频网站。A站以视频为载体,逐步发展出基于原生内容二次创作的完整生态,拥有高质量互动弹幕,是中国弹幕文化的发源地;拥有大量超粘性的用户群体,产生输出了金坷垃、鬼畜全明星、我的滑板鞋、小苹果等大量网络流行文化,也是中国二次元文化的发源地。 B站 全称“哔哩哔哩(bilibili...

终于,月薪过5万了!

来看几个问题想不想月薪超过5万?想不想进入公司架构组?想不想成为项目组的负责人?想不想成为spring的高手,超越99%的对手?那么本文内容是你必须要掌握的。本文主要详解bean的生命...

MySQL性能优化(五):为什么查询速度这么慢

前期回顾: MySQL性能优化(一):MySQL架构与核心问题 MySQL性能优化(二):选择优化的数据类型 MySQL性能优化(三):深入理解索引的这点事 MySQL性能优化(四):如何高效正确的使用索引 前面章节我们介绍了如何选择优化的数据类型、如何高效的使用索引,这些对于高性能的MySQL来说是必不可少的。但这些还完全不够,还需要合理的设计查询。如果查询写的很糟糕,即使表结构再合理、索引再...

用了这个 IDE 插件,5分钟解决前后端联调!

点击上方蓝色“程序猿DD”,选择“设为星标”回复“资源”获取独家整理的学习资料!作者 |李海庆我是一个 Web 开发前端工程师,受到疫情影响,今天是我在家办公的第78天。开发了两周,...

大厂的 404 页面都长啥样?最后一个笑了...

每天浏览各大网站,难免会碰到404页面啊。你注意过404页面么?猿妹搜罗来了下面这些知名网站的404页面,以供大家欣赏,看看哪个网站更有创意: 正在上传…重新上传取消 腾讯 正在上传…重新上传取消 网易 淘宝 百度 新浪微博 正在上传…重新上传取消 新浪 京东 优酷 腾讯视频 搜...

【高并发】高并发秒杀系统架构解密,不是所有的秒杀都是秒杀!

网上很多的文章和帖子中在介绍秒杀系统时,说是在下单时使用异步削峰来进行一些限流操作,那都是在扯淡! 因为下单操作在整个秒杀系统的流程中属于比较靠后的操作了,限流操作一定要前置处理,在秒杀业务后面的流程中做限流操作是没啥卵用的。

自从喜欢上了B站这12个UP主,我越来越觉得自己是个废柴了!

不怕告诉你,我自从喜欢上了这12个UP主,哔哩哔哩成为了我手机上最耗电的软件,几乎每天都会看,可是吧,看的越多,我就越觉得自己是个废柴,唉,老天不公啊,不信你看看…… 间接性踌躇满志,持续性混吃等死,都是因为你们……但是,自己的学习力在慢慢变强,这是不容忽视的,推荐给你们! 都说B站是个宝,可是有人不会挖啊,没事,今天咱挖好的送你一箩筐,首先啊,我在B站上最喜欢看这个家伙的视频了,为啥 ,咱撇...

代码注释如此沙雕,会玩还是你们程序员!

某站后端代码被“开源”,同时刷遍全网的,还有代码里的那些神注释。 我们这才知道,原来程序员个个都是段子手;这么多年来,我们也走过了他们的无数套路… 首先,产品经理,是永远永远吐槽不完的!网友的评论也非常扎心,说看这些代码就像在阅读程序员的日记,每一页都写满了对产品经理的恨。 然后,也要发出直击灵魂的质问:你是尊贵的付费大会员吗? 这不禁让人想起之前某音乐app的穷逼Vip,果然,穷逼在哪里都是...

Java14 新特性解读

Java14 已于 2020 年 3 月 17 号发布,官方特性解读在这里:https://openjdk.java.net/projects/jdk/14/以下是个人对于特性的中文式...

爬虫(101)爬点重口味的

小弟最近在学校无聊的很哪,浏览网页突然看到一张图片,都快流鼻血。。。然后小弟冥思苦想,得干一点有趣的事情python 爬虫库安装https://s.taobao.com/api?_ks...

疫情后北上广深租房价格跌了吗? | Alfred数据室

去年3月份我们发布了《北上广深租房图鉴》(点击阅读),细数了北上广深租房的各种因素对租房价格的影响。一年过去了,在面临新冠疫情的后续影响、城市尚未完全恢复正常运转、学校还没开学等情况下...

面试官给我挖坑:a[i][j] 和 a[j][i] 有什么区别?

点击上方“朱小厮的博客”,选择“设为星标”后台回复&#34;1024&#34;领取公众号专属资料本文以一个简单的程序开头——数组赋值:int LEN = 10000; int[][] ...

又一起程序员被抓事件

就在昨天互联网又发生一起让人心酸的程序员犯罪事件,著名的百度不限速下载软件 Pandownload PC 版作者被警方抓获。案件大致是这样的:软件的作者不仅非法盗取用户数据,还在QQ群进...

应聘3万的职位,有必要这么刁难我么。。。沙雕。。。

又一次被面试官带到坑里面了。面试官:springmvc用过么?我:用过啊,经常用呢面试官:springmvc中为什么需要用父子容器?我:嗯。。。没听明白你说的什么。面试官:就是contr...

太狠了,疫情期间面试,一个问题砍了我5000!

疫情期间找工作确实有点难度,想拿到满意的薪资,确实要点实力啊!面试官:Spring中的@Value用过么,介绍一下我:@Value可以标注在字段上面,可以将外部配置文件中的数据,比如可以...

Intellij IDEA 美化指南

经常有人问我,你的 IDEA 配色哪里搞的,我会告诉他我自己改的。作为生产力工具,不但要顺手而且更要顺眼。这样才能快乐编码,甚至降低 BUG 率。上次分享了一些 IDEA 有用的插件,反...

【相亲】96年程序员小哥第一次相亲,还没开始就结束了

颜值有点高,条件有点好

太厉害了,终于有人能把TCP/IP 协议讲的明明白白了

一图看完本文 一、 计算机网络体系结构分层 计算机网络体系结构分层 计算机网络体系结构分层 不难看出,TCP/IP 与 OSI 在分层模块上稍有区别。OSI 参考模型注重“通信协议必要的功能是什么”,而 TCP/IP 则更强调“在计算机上实现协议应该开发哪种程序”。 二、 TCP/IP 基础 1. TCP/IP 的具体含义 从字面意义上讲,有人可能会认为...

腾讯面试题: 百度搜索为什么那么快?

我还记得去年面腾讯时,面试官最后一个问题是:百度/google的搜索为什么那么快? 这个问题我懵了,我从来没想过,搜素引擎的原理是什么 然后我回答:百度爬取了各个网站的信息,然后进行排序,当输入关键词的时候进行文档比对……巴拉巴拉 面试官:这不是我想要的答案 我内心 这个问题我一直耿耿于怀,终于今天,我把他写出来,以后再问,我直接把这篇文章甩给他!!! 两个字:倒排,将贯穿整篇文章,也是面试官...

相关热词 c# 按行txt c#怎么扫条形码 c#打包html c# 实现刷新数据 c# 两个自定义控件重叠 c#浮点类型计算 c#.net 中文乱码 c# 时间排序 c# 必备书籍 c#异步网络通信
立即提问