$.ajax总是失败进入error

图片说明
图片说明
图片说明

请求总是进入error 无法进入后台, 状态为404,状态码为4。其他的ajax请求都没问题,就这个不行

17个回答

路径不全:
http://localhost:8080/ssm/emp/2
http://localhost:端口号/ssm项目名字/conroller层的RequestMapping/方法RequestMapping
注意。
1.例如ideal配置tomcat
图片说明
所以项目名字可能在不需要,取决你的配置
2。例如springmvc我的control和function的配置
图片说明

qq_36752786
qq_36752786 就是个小实验,URL是不太规范,单也不应该出错才对。后台前台分开测试都没问题,放在一起就请求不到后台。怎么搞都不行,最后放了一天,clean了一下服务器,自己突然就好了。关键是我之前已经clean无数次都不管用啊,真要被逼疯了!
大约 2 年之前 回复
qq_20766085
huhuhuHR 我感觉还有一种可能<context:component-scan base-package="com.xxxx"/>这个没扫描到你的controller
大约 2 年之前 回复

说明映射错了。一般只能通过调试来解决。你的项目名是ssm吗?还是说你的类上有@RequestMapping("/ssm")注解。只是看暂时看不出来。

实在不行,其实可以考虑试试不要RestFul风格的写法,看看有没有进去方法体中。

404根本没找到,Controller类标签添加了@Controller了么

qq_36752786
qq_36752786 肯定标了,这个类的其他方法都没问题
大约 2 年之前 回复

你检查一下ajax 请求的路径不对

qq_36752786
qq_36752786 我都换了好几个了,路径肯定没问题
大约 2 年之前 回复

状态为404,状态码为4。其他的ajax请求都没问题

这难道不是请求的url路径有问题?

把你后台代码贴过来看一下。这问题出在后台

是不是命名出现问题了?

老铁 不应该是POST请求吗?为何是GET?

qq_33277465
有需求加qq228795476 能不逗吗
大约 2 年之前 回复
共17条数据 1 尾页
Csdn user default icon
上传中...
上传图片
插入图片
抄袭、复制答案,以达到刷声望分或其他目的的行为,在CSDN问答是严格禁止的,一经发现立刻封号。是时候展现真正的技术了!
其他相关推荐
jquery ajax 请求一直返回当前页面HTML代码
前端JS var names =$("#names").val(); if(isNull(names)){ alertMsg({'msg':'请输入姓名!'}); return; } var job_number =$("#job_number").val(); if(isNull(job_number)){ alertMsg({'msg':'请输入工号!'}); return; } var email =$("#email").val(); if(isNull(email)){ alertMsg({'msg':'请输入邮箱'}); return; } $.ajax({ type:"post", url:"memberBinding.do", data:{'names':names,'job_number':job_number,'email':email}, dataType:"json", success:function(result){ alert(result); alert(result.error); alert(result.msg); return; }, error:function(XMLHttpRequest, textStatus, errorThrown){ alert(XMLHttpRequest.status); alert(XMLHttpRequest.readyState); alert(textStatus); alert("Ajax获取数据失败!"); } }); 后端处理代码: public String memberBinding() throws Exception { JSONObject json = new JSONObject(); json.put("error", "1"); json.put("msg", "验证成功"); JSONUtils.printObject(json); return null; } 问题描述: 执行这个请求实际是没有发送到服务端去,可是却进入了 success,并且result 返回的数据是当前这个页面的所有HTML元素。改变dataType 为HTML 还是没有用,但是会进入error,status=200,readyState=4,textStatus=parsererror。 这个请求都没有发送到服务端,我已经在服务端跟踪了,没有响应请求。另外服务端返回的结果是JSON字符串格式的数组。服务器端直接用地址栏的形式是可以返回数据的,并且没有任何异常,返回内容{"error":"1","msg":"验证成功"}
ajax一直不进入success:function()总是提示获取不到数据
public class UserDaoImpl implements UserDao { @Override public User login(User user) { Connection con = null; PreparedStatement ps = null; ResultSet rs = null; try { con = BaseDao.getCon(); String sql = "select * from user where name=? and password=?"; ps = con.prepareStatement(sql); ps.setString(1, user.getName()); ps.setString(2, user.getPassword()); rs = ps.executeQuery(); User users; if (rs.next()) { users = new User(); System.out.println(); users.setId(rs.getInt("id")); users.setName(rs.getString("name")); users.setPassword(rs.getString("password")); users.setEmail(rs.getString("email")); users.setPhone(rs.getString("phone")); users.setMoney(rs.getString("money")); return users; } else { return null; } } catch (ClassNotFoundException e) { // TODO Auto-generated catch block e.printStackTrace(); } catch (SQLException e) { // TODO Auto-generated catch block e.printStackTrace(); } return null; } @Override public boolean register(User user) { String sql = "insert into user values(0,?,?,?,?,?) "; List<Object> list = new ArrayList<Object>(); list.add(user.getName()); list.add(user.getPassword()); list.add(user.getEmail()); list.add(user.getPhone()); list.add(user.getMoney()); boolean flag = BaseDao.addUpdateDelete(sql, list.toArray()); if (flag) { return true; } else { return false; } } public ArrayList<User> query() { Connection con = null; ArrayList<User> barArr = new ArrayList<User>(); try { con = BaseDao.getCon(); PreparedStatement stmt = con.prepareStatement("select * from user"); ResultSet rs = stmt.executeQuery(); while (rs.next()) { User bar = new User(); bar.setName(rs.getString("name")); bar.setMoney(rs.getString("money")); barArr.add(bar); } con.close(); } catch (SQLException e) { e.printStackTrace(); } catch (ClassNotFoundException e) { // TODO Auto-generated catch block e.printStackTrace(); } return barArr; } } @WebServlet("/user/userlogin") public class UserLoginServlet extends HttpServlet { private static final long serialVersionUID = 1L; @Override protected void doGet(HttpServletRequest request, HttpServletResponse response) throws ServletException, IOException { this.doPost(request, response); } @Override protected void doPost(HttpServletRequest request, HttpServletResponse response) throws ServletException, IOException { User user = new User(); // 获取login.jsp页面提交的账号和密码 String name = request.getParameter("name"); String password = request.getParameter("password"); String money=request.getParameter("money"); // 测试数据 System.out.println(name + " " + password+" "+money); // 获取login.jsp页面提交的账号和密码设置到实体类User? user.setName(name); user.setPassword(password); HttpSession session = request.getSession(); // 引入数据交互层 UserDao dao = new UserDaoImpl(); User us = dao.login(user); // 测试返回的值 System.out.println(us); if (us != null) { session.setAttribute("user", user); request.getRequestDispatcher("/index/echarts.jsp").forward(request, response); // request.setAttribute("info", "登录成功"); } else { request.setAttribute("info", "登录失败"); request.getRequestDispatcher("/index/info.jsp").forward(request, response); } UserDaoImpl barDao = new UserDaoImpl(); ArrayList<User> barArr = barDao.query(); response.setContentType("text/html; charset=utf-8"); JSONArray json = JSONArray.fromObject(barArr); System.out.println("得到的数据:"+json.toString()); PrintWriter writer = response.getWriter(); writer.println(json); writer.flush(); writer.close(); } } public class BaseDao { private static String driver; private static String url; private static String user; private static String password; private static String money; static { driver = ResourceBundle.getBundle("db").getString("driver"); url = ResourceBundle.getBundle("db").getString("url"); user = ResourceBundle.getBundle("db").getString("user"); password = ResourceBundle.getBundle("db").getString("password"); } public static Connection getCon() throws ClassNotFoundException, SQLException { Class.forName(driver); System.out.println("测试加载数据库成功"); Connection con = DriverManager.getConnection(url, user, password); System.out.println("测试数据库连接成功"); return con; } public static void close(Connection con, PreparedStatement ps, ResultSet rs) { if (rs != null) {// 关闭 try { rs.close(); } catch (SQLException e) { // TODO Auto-generated catch block e.printStackTrace(); } } if (ps != null) { try { ps.close(); } catch (SQLException e) { // TODO Auto-generated catch block e.printStackTrace(); } } if (con != null) { try { con.close(); } catch (SQLException e) { // TODO Auto-generated catch block e.printStackTrace(); } } } public static boolean addUpdateDelete(String sql, Object[] arr) { Connection con = null; PreparedStatement ps = null; try { con = BaseDao.getCon();// 第一步 :连接数据库的操作 ps = con.prepareStatement(sql);// 第二步:预编译 // 第三步:设置值 if (arr != null && arr.length != 0) { for (int i = 0; i < arr.length; i++) { ps.setObject(i + 1, arr[i]); } } int count = ps.executeUpdate();// 第四步:执行sql语句 if (count > 0) { return true; } else { return false; } } catch (ClassNotFoundException e) { // TODO Auto-generated catch block e.printStackTrace(); } catch (SQLException e) { // TODO Auto-generated catch block e.printStackTrace(); } return false; } } <%@page import="org.apache.catalina.connector.Request"%> <%@ page language="java" import="java.util.*" pageEncoding="UTF-8"%> <% String path = request.getContextPath(); String basePath = request.getScheme() + "://" + request.getServerName() + ":" + request.getServerPort() + path + "/"; %> <!DOCTYPE html PUBLIC "-//W3C//DTD HTML 4.01 Transitional//EN" "http://www.w3.org/TR/html4/loose.dtd"> <head> <meta http-equiv="Content-Type" content="text/html; charset=UTF-8"> <title>Hello ECharts</title> <!-- 使用单文件引入的方式使用ECharts.JS --> <script type="text/javascript" src="../scripts/echarts-all.js"></script> <script type="text/javascript" src="../scripts/jquery.js"></script> </head> <body> 您的用户名是: ${user.name} <div id="myDiv" style="height: 400px"></div> <script type="text/javascript"> function loadData(option) { $.ajax({ type : 'post', //传输类型 async : false, url : 'bar.do', //web.xml中注册的Servlet的url-pattern data : { "name" : name }, dataType : 'json', //返回数据形式为json success : function(result) { if (result) { option.legend.data = []; option.series[0].data = []; for (var i = 0; i < result.length; i++) { alert(result[i].name + "---" + result[i].money); option.legend.data.push(result[i].name); option.series[0].data.push({ name : result[i].name, value : result[i].money }); } myChart.setOption(option); } }, error : function(errorMsg) { alert("加载数据失败"+errorMsg); } });//AJAX }//loadData() var myChart = echarts.init(document.getElementById('myDiv')); var option = { title : { text : '某站点用户访问来源', subtext : '纯属虚构', x : 'center' }, tooltip : { trigger : 'item', formatter : "{a} {b} : {c} ({d}%)" }, legend : { orient : 'vertical', left : 'left', data : [] }, series : [ { name : '访问来源', type : 'pie', radius : '55%', center : [ '50%', '60%' ], data : [], itemStyle : { emphasis : { shadowBlur : 10, shadowOffsetX : 0, shadowColor : 'rgba(0, 0, 0, 0.5)' } } } ] }; //加载数据到option loadData(option); //设置option </script> </body>
SpringMVC 进入页面Ajax自动提交,但是为什么modelAndView返回该页的时候,在页面取不到后台的值呢?
# 前台Ajax ``` <script type="text/javascript"> $(function(){ alert("查询信息"); var para ={userName:'lxw'}; var url = root + "/lxwempAjax/lxwOptionalStock"; $.ajax({ type:"POST", url:url, data:para, datatype:'json', success:function(result){ alert('提交成功'+para.userName); }, error:function(result){ alert('提交失败'+para.userName); } }); alert("执行完成"); }) </script> ``` <label>${resquestScope.res[0].StockName }44444444</label> ``` ``` # 后台: ``` @RequestMapping(value="/lxwOptionalStock") public ModelAndView getOptionalStock(Page page){ ModelAndView mv=new ModelAndView(); PageData pd = new PageData(); List<PageData> res = new ArrayList<PageData>(); boolean result = false; try { pd=this.getPageData(); System.out.println(pd.toString()+"c"); res = this.lxwstockexchangefacade.selectOptionalStock(pd); result = true; } catch (Exception e) { // TODO: handle exception logger.error(e); e.printStackTrace(); } mv.addObject("res", res); System.out.println(res.toString()); mv.addObject("result", result); mv.setViewName("lxw/personCenter"); return mv; } ``` <label>${res[0].StockName }44444444</label>页面里面只有4444 困扰了好长时间了,求解!! 新更: .. ``` <label>${res[0].StockName }</label> ${requestScope.name } ${result } <div class="Top_div"> <a class="top_a1" >个人中心</a> <a class="top_a2" href="../lxl/login">退出</a> </div> ``` 就是这样 在F12浏览器调试那里 respon里面可以值出来,但是就是没法在页面显示
ssm+ajax查询数据库无反应
求好心哥哥帮忙,前面发了一次问题,不知道为什么没发布出来,再发一遍 先是前端的Admin.jsp代码 ``` <%@ page language="java" import="java.util.*" pageEncoding="utf-8"%> <% String path = request.getContextPath(); String basePath = request.getScheme()+"://"+request.getServerName()+":"+request.getServerPort()+path+"/"; %> <!DOCTYPE HTML PUBLIC "-//W3C//DTD HTML 4.01 Transitional//EN"> <html> <head> <title>管理员界面</title> <script type="text/javascript" charset="utf-8"> $("#thisList").click(function(){ $.ajax({ type:"POST", url:"/returnMap", error:function(){ alert("error!--说明服务器返回失败"); }, dataType:"json", success:function(data){ $("#resultTable").empty(); var thisListValueStr=""; console.log(data.length+"条数据"); for(var i=0;i<data.length;i++){ var caseList=dada[i]; thisListValueStr="<tr><td>"+caseList.user_id+"</td><td>"+caseList.username+"</td><td>"+caseList.password+"</td></tr>"; $("#resultTable").append(thisListValueStr); thisListValueStr=""; } } }); }); </script> </head> <body> <button id="thisList" class="btn btn-default">获取数据</button> <table class="table"> <thead> <tr> <th>user_id</th> <th>username</th> <th>password</th> </tr> </thead > <tbody id="resultTable"> </tbody> </table> </body> </html> ``` 然后是controller层 ``` @RequestMapping(value="/returnMap",produces="text/heml;charset=UTF-8;") @ResponseBody public String returnMap(){ Map map1 = new HashMap(); map1.put("user_id","1001"); map1.put("username","李俊成"); map1.put("password","男"); Map map2 = new HashMap(); map2.put("user_id","1002"); map2.put("username","伍天秀"); map2.put("password","女"); String json=JSONArray.toJSONString(map1); System.out.println(json); return json; } ``` 这也是从网上抄的一段代码,但是用tomcat运行后可以进入界面但是点击按钮没有任何反应,controller层的方法也没有调用,昨天刚接触的ajax所以对这个不了解 我的目标是点击这个按钮,可以不刷新界面然后从我数据库的user表查询并返回出所有信息,然后可以对信息进行增删改操作,当然现在没有涉及到数据库都出错了。。 有没有老哥能指点一下迷津我哪里写错了,或者有别的方法能达到我这个目的的,小弟感激不尽,在线等
AJAX长连接的服务器线程问题
正在学习AJAX的长连接的问题 在客户端用ajax去实现连接   $.ajax({       url: '/ajax',       type: 'GET',       data: 'what=test',       timeout: 30000,       //请求成功后触发       success: function (data) { clock = clock+1; show.prepend('success invoke!' +data+'<br/>'); switch(data){ case "error data": //RevServer(); break; case "ok": RevServer(); break; default: } },       //请求失败遇到异常触发       error: function (xhr, errorInfo, ex) { clockErr = clockErr+1; show.prepend('error invoke!errorInfo:'+ errorInfo+"次数"+clockErr+'<br/>'); RevServer(); },       //完成请求后触发。即在success或error触发后触发       complete: function (xhr, status) { show.prepend('complete invoke! status:' + status+",次数"+clock+'<br/>'); //RevServer(); } 现在出现一个问题,服务器端我之前是用while直接循环,但是好像多几次后就会使服务器产生异常。然后就往while里加了一个thread,但是这样一样,客户端就失效了,直接 进入了complete,如果不加thread就会一直处在连接中,加了线程连接就直接结束了。 switch(what){ case "test": Thread test = new Thread(new Runnable(){//这里加了线程后,客户端就结束了 public void run(){ while(a){ if(session.getAttribute("status")=="ok")a=false; } out.print("收到你的消息"); a = true; session.setAttribute("status","nothing"); } }); test.start(); break; case "setStatus": session.setAttribute("status","ok"); break; } } 不加线程,就会比较好的运行。(不过感觉性能有问题) switch(what){ case "test": while(a){ if(session.getAttribute("status")=="ok")a=false; } out.print("收到你的消息"); a = true; session.setAttribute("status","nothing"); } break; case "setStatus": session.setAttribute("status","ok"); break; } } 请大家帮忙看看,如何加了线程让客户端良好运行呢你?
前台ajax传值后台controller取不到。
**我的HTML** ``` <body > <p id="weixinhao" class="weixinhao" onclick="huoquValues()">123456</p> <script type="text/javascript" src="../layui/jsplug/jquery-1.8.3.min.js"></script> <script type="text/javascript"> var count=0; function huoquValues(){ var value=document.getElementById("weixinhao");//获取p标签值 alert(value.innerText); count++;//模拟赋值次数 alert(count); var URL = window.location.href;//获取当前URL alert(URL); var params=[]; params.value=value; params.count=count; params.URL=URL; $.ajax({ type:'post',//请求方式 url:'/update',//请求地址 dataType:'json',//返回格式 data:params, error:function() { alert('请求失败'); }, success:function(params){ alert('请求成功'); } }); } ``` **我的controller** ``` @RequestMapping("update") @ResponseBody public Map<String,Object> update(String value,Integer count,String URL){ System.out.println("已进入"); System.out.println(value); System.out.println(count); System.out.println(URL); Map<String,Object> resultMap = new HashMap<String, Object>(); if(value == null || count==0||URL == null){ resultMap.put("result", "参数不合法!"); return resultMap; } resultMap.put("result", "操作成功"); return resultMap; } ``` 谢谢各位同志赐教,已解决。我这写的确实太麻烦了,我换了种方式可以传值到后台了。 ``` var count=0; function huoquValues(){ var value=document.getElementById("weixinhao").innerText;//获取p标签值 alert(value); count++;//模拟赋值次数 alert(count); var URL = window.location.href;//获取当前URL alert(URL); $.post("/addWX","value="+value+"&count="+count+"&URL="+URL ,function(data){ if(data!=null){ alert("成功_ajax"); } },"text") } ``` 解决了的问答不知道怎么下掉,看到这问答的伙伴们路过就可以了。
我如下遍历之后添加一级菜单没事,但是添加二级的时候菜单的值就是未定义,可以成功添加到数据库,求大神指教
<%@ page language="java" import="java.util.*" pageEncoding="UTF-8"%> <%@taglib prefix="c" uri="http://java.sun.com/jsp/jstl/core"%> <% String path = request.getContextPath(); String basePath = request.getScheme() + "://" + request.getServerName() + ":" + request.getServerPort() + path + "/"; %> <link rel="stylesheet" type="text/css" href="css/shopbs/catalogDesign.css"> <div class="addDirectory-content"> <div class="addDirectory" id="addDirectoryNavigation"> <div class="addDirectoryLeft"> <label id="labels">添加菜单<img src="img/order/jia (2).png" /></label> </div> <div class=addDirectoryRight> <button type="button" onclick="addShopmenus()">保存</button> </div> </div> <div class="addMenu"> <c:forEach items="${shopmenulist }" var="navigations"> <div class="aNavigationBar aNavigationBar-list"> <ul class="clearfix navigationOne"> <li class="oneType">一级菜单</li> <li>名称&nbsp:&nbsp<span>${navigations.name }</span></li> <li>序号&nbsp:&nbsp<span>${navigations.sort }</span></li> <li>类型&nbsp:&nbsp<span>${navigations.type }</span></li> <li><form id="shopmenus_id" method="post"> <label for="select"> </label> <select name="select">操作 <option value="1">修改</option> </select> <input type="text" id="shopmenu_name" name="name" value="${navigations.name}"> <input type="text" id="shopmenu_sort" name="sort" value="${navigations.sort}"> <input type="text" id="shopmenu_type" name="type" value="${navigations.type}"> <input type="hidden" id="shopmenu_id" name="id" value="${navigations.id}"> <input type="button" value="保存" onclick="updatemenus_first()"> </form></li> <li class="addNavigation"><img src="img/order/jia (2).png" title="添加二级菜单" onclick="getId('${navigations.id}');" /></li> </ul> <div class="navigationTwo"> <c:forEach items="${navigations.submenus }" var="list"> <ul class="clearfix"> <li class="oneType">二级菜单</li> <li>名称&nbsp:&nbsp<span>${list.name }</span></li> <li>序号&nbsp:&nbsp<span>${list.sort }</span></li> <li>类型&nbsp:&nbsp<span>${list.type }</span></li> <li> <form id="secondsmenus" method="post"> <label for="select"> </label> <select name="select">操作 <option value="1">修改</option> </select> <input type="text" id="list_name" name="name" value="${list.name }"> <input type="text" id="list_sort" name="sort" value="${list.sort }"> <input type="text" id="list_type" name="type" value="${list.type }"> <input type="hidden" id="list_id" name="name" value="${list.id }"> <input type="button" value="保存" onclick="updatemenus_second()"> </form> </li> <li class="addNavigation"> <!-- <img src="img/order/jia (2).png" /> --> </li> </ul> </c:forEach> <ul class="clearfix addnavigationTwo"> <li class="oneType">二级菜单</li> <li>名称&nbsp:&nbsp<input id="shopname" name="name" /></li> <li>序号&nbsp:&nbsp<input id="${navigations.id }" name="sort" /></li> <li>类型&nbsp:&nbsp<input id="shoptype" name="type" value="0" /></li> <li> <form name="form1" method="post"> <label for="select"> </label> <select name="select"> <option value="1">操作</option> <option value="2">删除</option> <option value="3">修改</option> </select> </form> </li> <li class="addNavigation"> <!-- <img src="img/order/jia (2).png" /> --> </li> </ul> </div> </div> </c:forEach> </div> <div class="aNavigationBar" id="addAbusinessCategory"> <ul class="clearfix"> <li class="oneType">一级菜单</li> <li>名称&nbsp:&nbsp<input id="first_names" name="name" /></li> <li>序号&nbsp:&nbsp<input id="first_sorts" name="sort" /></li> <li>类型&nbsp:&nbsp<input id="first_types" name="type" value="0" /></li> <li> <form name="form1" method="post"> <label for="select"> </label> <select name="select"> <option value="1">操作</option> <option value="2">删除</option> <option value="3">修改</option> </select> </form> </li> <li class="addNavigation"><img src="img/order/jia (2).png" /></li> </ul> </div> <input type="hidden" id="shopmenu_shopId"> </div> <script type="text/javascript"> $("#addDirectoryNavigation").mouseover(function() { $("#addDirectoryLeft .addDirectoryLeft").show(); }).mouseleave(function() { $("#addDirectoryLeft .addDirectoryLeft").hide(); }) $("#addDirectoryNavigation .addDirectoryLeft label").click(function() { $(".aNavigationBar").show(); }); $(" .addNavigation img").click(function() { $("#twoTypesOfBusinesses").show(); }); $(function() { $(".aNavigationBar").on( "click", ".addNavigation", function() { $(this).parents(".aNavigationBar") .find(".addnavigationTwo").show(); }); }); function getId(id, index) { $("#shopmenu_shopId").val(id); } function addShopmenus() { var parinfo = $("#shopmenu_shopId").val(); $("#shopmenu_shopId").val(""); if (parinfo == "" || parinfo == null) { $.ajax({ type : "POST", url : "merchantcenter/addcatalogDesign", data : { name : $("#first_names").val(), sort : $("#first_sorts").val(), type : $("#first_types").val(), }, success : function(result) { if (result.status == 1) { alertMsg.correct("添加一级菜单成功"); $("#navigationDesign").click(); } else { alertMsg.error("非法操作"); } } }); } else { $.ajax({ type : "POST", url : "merchantcenter/addsubshopmenu", data : { name : $("#shopname").val(), sort : $("#" + parinfo + "").val(), parentId : parinfo, type : $("#shoptype").val(), }, success : function(result) { if (result.status == 1) { alertMsg.correct("添加二级菜单成功"); $("#navigationDesign").click(); } else { alertMsg.error("非法操作"); } } }); } } function updatemenus_first() { $.ajax({ type : "POST", url : "merchantcenter/updateShopmenus", data : { id : $("#shopmenu_id").val(), name : $("#shopmenu_name").val(), sort : $("#shopmenu_sort").val(), type : $("#shopmeun_type").val(), }, success : function(result) { if (result.status == 1) { alertMsg.correct("更新一级菜单成功"); $("#navigationDesign").click(); } else { alertMsg.error("更新失败"); } } }); } function updatemenus_second() { $.ajax({ type : "POST", url : "merchantcenter/updateShopmenus", data : { id : $("#list_id").val(), name : $("#list_name").val(), sort : $("#list_sort").val(), type : $("#list_type").val(), }, success : function(result) { if (result.status == 1) { alertMsg.correct("更新二级菜单成功"); $("#navigationDesign").click(); } else { alertMsg.error("更新失败"); } } }); } </script> 这是前台遍历与添加菜单的代码 /** * 跳转目录设计 */ @RequestMapping(value = "/tocatalogDesign") public ModelAndView tocatalogDesign(HttpServletRequest request) { Map<String, Object> result = new HashMap<String, Object>(); Shop shop = (Shop)request.getSession().getAttribute("shop"); List<Shopmenu>shopmenulist = shopmenuService.queryBySqlQuery("from Shopmenu sm where sm.parentId is null and sm.type=0 and sm.shop.id=?", new Object[]{shop.getId()}); result.put("shopmenulist", shopmenulist); return new ModelAndView("shopbs/order/catalogDesign",result); } /** * 目录设计 一级菜单 */ @RequestMapping(value="/addcatalogDesign",method = RequestMethod.POST) @ResponseBody public Map<String, Object> addcatalogDesign (HttpServletRequest request,Shopmenu shopmenu){ System.out.println("进入非法"); Map<String, Object>result = new HashMap<String,Object>(); Shop shop = (Shop)request.getSession().getAttribute("shop"); String warnInfo = ""; int status = 0; if(Common.isNull(shopmenu.getParentId())){ shopmenu.setShop(shop); shopmenu.setType(0); shopmenuService.save(shopmenu); warnInfo = "添加一级菜单成功"; status = 1; } result.put("warnInfo", warnInfo); result.put("status", status); return result; } /** * 目录设计 二级菜单 */ @RequestMapping(value="/addsubshopmenu",method = RequestMethod.POST) @ResponseBody public Map<String, Object> addsubshopmenu(HttpServletRequest request,Shopmenu shopmenu){ System.out.println("进入合法"); Map<String, Object>result = new HashMap<String,Object>(); Shop shop = (Shop)request.getSession().getAttribute("shop"); String warnInfo = ""; int status = 0; if(!Common.isNull(shopmenu.getParentId())){ shopmenu.setShop(shop); shopmenu.setType(0); shopmenuService.save(shopmenu); warnInfo = "添加二级菜单成功"; status = 1; }else{ warnInfo = "非法操作"; } result.put("warnInfo", warnInfo); result.put("status", status); return result; } 这是后台查询及添加菜单代码
手机测试 wx.config 无反应,愿意发微信红包, 求大佬帮忙分析解决
我在微信开发工具测试, wx.config 显示ok , wx.chooseWXPay.没有此SDK或暂不支持此SDK模拟 **问题出在, 我用手机测试 (ios,android) wx.config无反应,** erro和ready均不进入 wx.chooseWXPay也无法用, 我在https://mp.weixin.qq.com/debug/cgi-bin/sandbox?t=jsapisign 验证了签名是一毛一样的, 求教大佬, 我这代码是出了啥毛病 ``` <!doctype html> <%@ page language="java" contentType="text/html; charset=UTF-8" pageEncoding="UTF-8"%> <html lang="zh-cn"> <head> <%@include file="/pc/inc/commoncontent.inc"%> <script type="text/javascript" src="http://res.wx.qq.com/open/js/jweixin-1.2.0.js"></script> <script src="<%=contextPath%>/m/smartHotel/script/jquery.min.js" type="text/javascript"></script> <script type="text/javascript"> </script> <title>订单-支付</title> <span class="disb picNum padTB30"><i class="disib iconPic" onClick="openPic(this);" >3532rrrrrrrrrrrrrrrrrrrrrrrrrrrrrrrrrrrrrrrrrrrrrrrrrrrrrr张</i></span> </head> <body> <script type="text/javascript"> var appId1,timeStamp1,nonceStr1,packageStr1,signType1,paySign1; $(document).ready(function () { $.ajax({ url : contextPath+ "/weixin/hotelorder/wxPay.action", type:"post", dataType:'json', //接受数据格式 async: false, data:{url:window.location.href.split('#')[0].replace(/\&/g,"%26")},//传参,建议使用json //1:手机号, 2:房间数.3单价4总价 5: 当前bedid 6 :入住人 姓名 7 发票8 入住日离开日 error:function(data){//请求失败时处理 // alert(data); window.location.href = '<%=contextPath%>/m/smartHotel/html/yysb.html'/*预订失败页*/ }, success:function(data) { if( data) { appId1 = data.pay.appId; timeStamp1 = data.pay.timeStamp; nonceStr1 = data.pay.nonceStr; packageStr1 = data.pay.package; signType1 = data.pay.signType; paySign1 = data.pay.paySign; } wx.config({ debug:false, // 开启调试模式,调用的所有api的返回值会在客户端alert出来,若要查看传入的参数,可以在pc端打开,参数信息会通过log打出,仅在pc端时才会打印。 appId:data.pay.appId, // 必填,公众号的唯一标识 timestamp:data.config.timestamp, // 必填,生成签名的时间戳 nonceStr:data.config.noncestr, // 必填,生成签名的随机串 signature:data.config.configSign, // 必填,签名,见附录1 jsApiList:['chooseWXPay','closeWindow'] }); wx.error(function(res){ alert("error enter"); }); wx.ready(function(){ alert("ready enter"); pay(); }); //onBridgeReady(); // alert("success inter"); } }); }); function pay() { // config信息验证后会执行ready方法,所有接口调用都必须在config接口获得结果之后,config是一个客户端的异步操作,所以如果需要在页面加载时就调用相关接口,则须把相关接口放在ready函数中调用来确保正确执行。对于用户触发时才调用的接口,则可以直接调用,不需要放在ready函数中。 console.log(appId1 +" / "+ timeStamp1+" / " + nonceStr1+" / "+packageStr1 +" / "+ signType1+" / "+paySign1); wx.chooseWXPay({ timestamp:timeStamp1, // 支付签名时间戳,注意微信jssdk中的所有使用timestamp字段均为小写。但最新版的支付后台生成签名使用的timeStamp字段名需大写其中的S字符 nonceStr:nonceStr1, // 支付签名随机串,不长于 32 位 package:packageStr1, // 统一支付接口返回的prepay_id参数值,提交格式如:prepay_id=***) signType:signType1, // 签名方式,默认为'SHA1',使用新版支付需传入'MD5' paySign:paySign1, // 支付签名 success:function(res) { alert("8888888888888"); alert(res); alert(res.errMsg); console.log(res.errMsg); // 支付成功后的回调函数 if (res.errMsg == "chooseWXPay:ok") { //支付成功 alert('支付成功'); } else { alert(res.errMsg); } } }); } function onBridgeReady(){ alert("进入了onbridgeready"); WeixinJSBridge.log("889"); WeixinJSBridge.invoke( 'getBrandWCPayRequest', { "appId":appId1, //公众号名称,由商户传入 "timeStamp":timeStamp1, //时间戳,自1970年以来的秒数 "nonceStr":nonceStr1, //随机串 "package":packageStr1, "signType":"MD5", //微信签名方式: "paySign":paySign1 //微信签名 }, function(res){ WeixinJSBridge.log(res); alert("进入了success"); alert(res.errorMsg); // 使用以下方式判断前端返回,微信团队郑重提示:res.err_msg将在用户支付成功后返回 ok,但并不保证它绝对可靠。 if(res.errMsg == "get_brand_wcpay_request:ok") { alert("支付成功"); // window.location.href = "${pageContext.request.contextPath}/wx/success?orderId=${orderId}"; }else if(res.errMsg == "get_brand_wcpay_request:fail"){ alert('支付失败'); }else if(res.errMsg == "get_brand_wcpay_request:cancel"){ alert('支付取消'); }else{ alert(res.errMsg); } } ); } function openPic() { pay(); //wx.closeWindow(); } //调用模拟 回调 // $.ajax({ // url : contextPath+ "/weixin/hotelorder/moniWXPay.action", // type:"post", // dataType:'json', //接受数据格式 // async: false, // data:{parm1:getQueryString2("orderId")},//传参,建议使用json // error:function(data){//请求失败时处理 // alert(data); // }, // success:function(data) // { // if(data.result =="success") // { // window.location.href = '<%=contextPath%>/m/smartHotel/html/yycg.jsp?orderId='+getQueryString2("orderId"); // } // // } // }); function getQueryString2(name) { var reg = new RegExp("(^|&)" + name + "=([^&]*)(&|$)", "i"); var r = window.location.search.substr(1).match(reg); if(r != null) return decodeURI(r[2]); return null; } </script> </body> </html> ```
文件上传$.ajaxFileUpload is not a function
使用ajaxFileUpload进行文件上传,在chrome浏览器脚本控制台报错:$.ajaxFileUpload is not a function,点击上传按钮没有响应。 代码如下: ``` <script type="text/javascript" src="js/jquery.min.js"></script> <script type="text/javascript" src="js/ajaxfileupload.js"></script> <script type="text/javascript"> function uploadFileByAjax() { //验证文件是否选择文件 var fileObj = $("#uploadFile"); var fileName = fileObj.attr("value"); if(fileName == null || fileName == ""){ return; } alert(fileName); $.ajaxFileUpload({ url : "/Itil/attamgn/upload", //需要链接到服务器地址 secureuri : false, fileElementId : "uploadFile", //文件选择框的id属性 dataType : "json", //服务器返回的格式,可以是json, xml success : function(data, status) //相当于java中try语句块的用法 { //alert("记录ID:" + data.seqId); //alert("文件名:" + data.uplName); attList.push(data.seqId); //修改显示文件列表 var content = "<li id=\"file" + fileIndex + "\" class=\"one-line border-radius-all attach\"><span class=\"name one-line\"><a class=\"ico ico-attach text\">"; content = content + data.uplName + "</a></span>"; content = content + "<span class=\"tool\"><a class=\"ico ico-remove hover\" title=\"删除\" onclick=\"deleteUploadFile('file"+fileIndex + "', '"+ data.seqId +"')\"></a></span></li>"; content = content + $("#fileList").html(); $("#fileList").html(content); }, error : function(data, status, e) //相当于java中catch语句块的用法 { alert("上传失败"); } } ); } </script> <body> <a><span id="" class="ico ico16 ico-attach hover ml10" title="添加附件" onclick="uploadFileByAjax(); return false; "></span></a> </body> ``` 哪位大神指点一下啊! 从访问时的页面源码可以进入引入的jquery.min.js和ajaxfileupload.js文件,可以确认引入没问题。
easyui datagrid 不显示json数据
过程描述:页面 A输入参数,进入controller进行逻辑处理并生成json数据,然后通过 MVC返回json数据,并对页面A相关easyui datagrid表格进行数据展示。 问题:easyui datagrid不现实数据,且页面不报错,调试能看到json数据。 页面代码: <table id="tt"></table> ``` <button id="myb" class="easyui-linkbutton c6" type="button" onclick="test()" >测试</button> function test(){ jq('#tt').datagrid({ title:'DataGrid - DetailView', width:500, height:250, remoteSort:false, singleSelect:true, nowrap:false, fitColumns:true, type:"POST", url:'/store/saleout/getjson', columns:[[ {field:'product_name',title:'Item ID',width:80}, {field:'numbers',title:'Product ID',width:100,sortable:true}, {field:'price',title:'List Price',width:80,align:'right',sortable:true}, {field:'buyer',title:'Unit Cost',width:80,align:'right',sortable:true} ]] }); alert("333"); } ``` 调试显示数据:{"rows":[{"product_name":"土豆","numbers":2,"price":40,"buyer":"A","style":"A","type":"WU","saleoutdate":"2015-3-31"}],"total":1} 请教一下:什么原因导致 easyui datagrid数据不显示?不报错,不知道到底从哪里入手,困扰了不短时间,多谢!! 页面完整代码如下,调试数据截图在附件中。 ![![图片说明](https://img-ask.csdn.net/upload/201505/31/1433004879_544586.png)图片说明](https://img-ask.csdn.net/upload/201505/31/1433004871_778225.png) ``` <!DOCTYPE html> <%@ page language="java" contentType="text/html; charset=utf-8" pageEncoding="utf-8"%> <%@ taglib prefix="spring" uri="http://www.springframework.org/tags"%> <%@ taglib prefix="fmt" uri="http://java.sun.com/jsp/jstl/fmt"%> <%@ taglib prefix="form" uri="http://www.springframework.org/tags/form"%> <%@ taglib prefix="fn" uri="http://java.sun.com/jsp/jstl/functions"%> <%@ taglib prefix="c" uri="http://java.sun.com/jsp/jstl/core"%> <html lang="en"> <jsp:include page="../fragments/staticFiles.jsp" /> <jsp:include page="../fragments/BootStrapFiles.jsp"/> <head> <meta charset="utf-8"> <title>saleout</title> <script type="text/javascript"> var jq = $.noConflict(); function test(){ jq('#tt').datagrid({ title:'DataGrid - DetailView', width:500, height:250, remoteSort:false, singleSelect:true, nowrap:false, fitColumns:true, type:"POST", url:'/store/saleout/getjson', columns:[[ {field:'product_name',title:'Item ID',width:80}, {field:'numbers',title:'Product ID',width:100,sortable:true}, {field:'price',title:'List Price',width:80,align:'right',sortable:true}, {field:'buyer',title:'Unit Cost',width:80,align:'right',sortable:true} ]] }); alert("333"); } jq(document).ready(function(){ jq("#ajax_pos").click( function (){alert("test"); jq.ajax({url:"<spring:url value="/saleout/precheck.html"/>", data:jq("#search_form").serialize(), contentType: "application/x-www-form-urlencoded; charset=UTF-8", type:"POST", success: function(data){ // jq("#tt").datagrid("load"); if( window.confirm(" 添加记录成功,是否继续添加?")){ // location.reload(); // alert(data.toString()); }else{ location.href="<spring:url value="/menu" htmlEscape="true"/>"; } }, error:function(data){alert("数据失败!"+data);}, }); }); }); </script> <style> ul { margin: 0; width: 100%; } li { margin: left; float: left; width: 100%; } </style> </head> <body> <div id="headmenu"> <jsp:include page="../saleOut/saleoutMenu.jsp"/> </div> <p></p> <table id="tt"></table> <button id="myb" class="easyui-linkbutton c6" type="button" onclick="test()" >测试</button> <div id="ajax_form" align="center" > <form:form modelAttribute="saleout" id="search_form" method="post"> <fieldset> <div id="product_name" align="left"> <label class="control-label">产品名称: </label> <form:input path="product_name" size="30" maxlength="80" /> </div> </fieldset> </form:form> <div id="_buttons"> <button id="ajax_pos" class="easyui-linkbutton c6" type="button" style="width: 80px; height: 35px" >提交</button> </div> </div> </body> </html> ```
终于明白阿里百度这样的大公司,为什么面试经常拿ThreadLocal考验求职者了
点击上面↑「爱开发」关注我们每晚10点,捕获技术思考和创业资源洞察什么是ThreadLocalThreadLocal是一个本地线程副本变量工具类,各个线程都拥有一份线程私...
程序员必须掌握的核心算法有哪些?
由于我之前一直强调数据结构以及算法学习的重要性,所以就有一些读者经常问我,数据结构与算法应该要学习到哪个程度呢?,说实话,这个问题我不知道要怎么回答你,主要取决于你想学习到哪些程度,不过针对这个问题,我稍微总结一下我学过的算法知识点,以及我觉得值得学习的算法。这些算法与数据结构的学习大多数是零散的,并没有一本把他们全部覆盖的书籍。下面是我觉得值得学习的一些算法以及数据结构,当然,我也会整理一些看过...
Linux(服务器编程):15---两种高效的事件处理模式(reactor模式、proactor模式)
前言 同步I/O模型通常用于实现Reactor模式 异步I/O模型则用于实现Proactor模式 最后我们会使用同步I/O方式模拟出Proactor模式 一、Reactor模式 Reactor模式特点 它要求主线程(I/O处理单元)只负责监听文件描述符上是否有事件发生,有的话就立即将时间通知工作线程(逻辑单元)。除此之外,主线程不做任何其他实质性的工作 读写数据,接受新的连接,以及处...
阿里面试官问我:如何设计秒杀系统?我的回答让他比起大拇指
你知道的越多,你不知道的越多 点赞再看,养成习惯 GitHub上已经开源 https://github.com/JavaFamily 有一线大厂面试点脑图和个人联系方式,欢迎Star和指教 前言 Redis在互联网技术存储方面使用如此广泛,几乎所有的后端技术面试官都要在Redis的使用和原理方面对小伙伴们进行360°的刁难。 作为一个在互联网公司面一次拿一次Offer的面霸,打败了...
五年程序员记流水账式的自白。
不知觉已中码龄已突破五年,一路走来从起初铁憨憨到现在的十九线程序员,一路成长,虽然不能成为高工,但是也能挡下一面,从15年很火的android开始入坑,走过java、.Net、QT,目前仍处于android和.net交替开发中。 毕业到现在一共就职过两家公司,目前是第二家,公司算是半个创业公司,所以基本上都会身兼多职。比如不光要写代码,还要写软著、软著评测、线上线下客户对接需求收集...
C语言魔塔游戏
很早就很想写这个,今天终于写完了。 游戏截图: 编译环境: VS2017 游戏需要一些图片,如果有想要的或者对游戏有什么看法的可以加我的QQ 2985486630 讨论,如果暂时没有回应,可以在博客下方留言,到时候我会看到。 下面我来介绍一下游戏的主要功能和实现方式 首先是玩家的定义,使用结构体,这个名字是可以自己改变的 struct gamerole { char n...
一文详尽系列之模型评估指标
点击上方“Datawhale”,选择“星标”公众号第一时间获取价值内容在机器学习领域通常会根据实际的业务场景拟定相应的不同的业务指标,针对不同机器学习问题如回归、分类、排...
究竟你适不适合买Mac?
我清晰的记得,刚买的macbook pro回到家,开机后第一件事情,就是上了淘宝网,花了500元钱,找了一个上门维修电脑的师傅,上门给我装了一个windows系统。。。。。。 表砍我。。。 当时买mac的初衷,只是想要个固态硬盘的笔记本,用来运行一些复杂的扑克软件。而看了当时所有的SSD笔记本后,最终决定,还是买个好(xiong)看(da)的。 已经有好几个朋友问我mba怎么样了,所以今天尽量客观...
程序员一般通过什么途径接私活?
二哥,你好,我想知道一般程序猿都如何接私活,我也想接,能告诉我一些方法吗? 上面是一个读者“烦不烦”问我的一个问题。其实不止是“烦不烦”,还有很多读者问过我类似这样的问题。 我接的私活不算多,挣到的钱也没有多少,加起来不到 20W。说实话,这个数目说出来我是有点心虚的,毕竟太少了,大家轻喷。但我想,恰好配得上“一般程序员”这个称号啊。毕竟苍蝇再小也是肉,我也算是有经验的人了。 唾弃接私活、做外...
压测学习总结(1)——高并发性能指标:QPS、TPS、RT、吞吐量详解
一、QPS,每秒查询 QPS:Queries Per Second意思是“每秒查询率”,是一台服务器每秒能够相应的查询次数,是对一个特定的查询服务器在规定时间内所处理流量多少的衡量标准。互联网中,作为域名系统服务器的机器的性能经常用每秒查询率来衡量。 二、TPS,每秒事务 TPS:是TransactionsPerSecond的缩写,也就是事务数/秒。它是软件测试结果的测量单位。一个事务是指一...
Python爬虫爬取淘宝,京东商品信息
小编是一个理科生,不善长说一些废话。简单介绍下原理然后直接上代码。 使用的工具(Python+pycharm2019.3+selenium+xpath+chromedriver)其中要使用pycharm也可以私聊我selenium是一个框架可以通过pip下载 pip installselenium -ihttps://pypi.tuna.tsinghua.edu.cn/simple/ ...
阿里程序员写了一个新手都写不出的低级bug,被骂惨了。
这种新手都不会范的错,居然被一个工作好几年的小伙子写出来,差点被当场开除了。
Java工作4年来应聘要16K最后没要,细节如下。。。
前奏: 今天2B哥和大家分享一位前几天面试的一位应聘者,工作4年26岁,统招本科。 以下就是他的简历和面试情况。 基本情况: 专业技能: 1、&nbsp;熟悉Sping了解SpringMVC、SpringBoot、Mybatis等框架、了解SpringCloud微服务 2、&nbsp;熟悉常用项目管理工具:SVN、GIT、MAVEN、Jenkins 3、&nbsp;熟悉Nginx、tomca...
2020年,冯唐49岁:我给20、30岁IT职场年轻人的建议
点击“技术领导力”关注∆每天早上8:30推送 作者|Mr.K 编辑| Emma 来源|技术领导力(ID:jishulingdaoli) 前天的推文《冯唐:职场人35岁以后,方法论比经验重要》,收到了不少读者的反馈,觉得挺受启发。其实,冯唐写了不少关于职场方面的文章,都挺不错的。可惜大家只记住了“春风十里不如你”、“如何避免成为油腻腻的中年人”等不那么正经的文章。 本文整理了冯...
程序员该看的几部电影
1、骇客帝国(1999) 概念:在线/离线,递归,循环,矩阵等 剧情简介: 不久的将来,网络黑客尼奥对这个看似正常的现实世界产生了怀疑。 他结识了黑客崔妮蒂,并见到了黑客组织的首领墨菲斯。 墨菲斯告诉他,现实世界其实是由一个名叫“母体”的计算机人工智能系统控制,人们就像他们饲养的动物,没有自由和思想,而尼奥就是能够拯救人类的救世主。 可是,救赎之路从来都不会一帆风顺,到底哪里才是真实的世界?如何...
Python绘图,圣诞树,花,爱心 | Turtle篇
每周每日,分享Python实战代码,入门资料,进阶资料,基础语法,爬虫,数据分析,web网站,机器学习,深度学习等等。 公众号回复【进群】沟通交流吧,QQ扫码进群学习吧 微信群 QQ群 1.画圣诞树 import turtle screen = turtle.Screen() screen.setup(800,600) circle = turtle.Turtle()...
作为一个程序员,CPU的这些硬核知识你必须会!
CPU对每个程序员来说,是个既熟悉又陌生的东西? 如果你只知道CPU是中央处理器的话,那可能对你并没有什么用,那么作为程序员的我们,必须要搞懂的就是CPU这家伙是如何运行的,尤其要搞懂它里面的寄存器是怎么一回事,因为这将让你从底层明白程序的运行机制。 随我一起,来好好认识下CPU这货吧 把CPU掰开来看 对于CPU来说,我们首先就要搞明白它是怎么回事,也就是它的内部构造,当然,CPU那么牛的一个东...
还记得那个提速8倍的IDEA插件吗?VS Code版本也发布啦!!
去年,阿里云发布了本地 IDE 插件 Cloud Toolkit,仅 IntelliJ IDEA 一个平台,就有 15 万以上的开发者进行了下载,体验了一键部署带来的开发便利。时隔一年的今天,阿里云正式发布了 Visual Studio Code 版本,全面覆盖前端开发者,帮助前端实现一键打包部署,让开发提速 8 倍。 VSCode 版本的插件,目前能做到什么? 安装插件之后,开发者可以立即体验...
破14亿,Python分析我国存在哪些人口危机!
一、背景 二、爬取数据 三、数据分析 1、总人口 2、男女人口比例 3、人口城镇化 4、人口增长率 5、人口老化(抚养比) 6、各省人口 7、世界人口 四、遇到的问题 遇到的问题 1、数据分页,需要获取从1949-2018年数据,观察到有近20年参数:LAST20,由此推测获取近70年的参数可设置为:LAST70 2、2019年数据没有放上去,可以手动添加上去 3、将数据进行 行列转换 4、列名...
2019年除夕夜的有感而发
天气:小雨(加小雪) 温度:3摄氏度 空气:严重污染(399) 风向:北风 风力:微风 现在是除夕夜晚上十点钟,再有两个小时就要新的一年了; 首先要说的是我没患病,至少现在是没有患病;但是心情确像患了病一样沉重; 现在这个时刻应该大部分家庭都在看春晚吧,或许一家人团团圆圆的坐在一起,或许因为某些特殊原因而不能团圆;但不管是身在何处,身处什么境地,我都想对每一个人说一句:新年快乐! 不知道csdn这...
听说想当黑客的都玩过这个Monyer游戏(1~14攻略)
第零关 进入传送门开始第0关(游戏链接) 请点击链接进入第1关: 连接在左边→ ←连接在右边 看不到啊。。。。(只能看到一堆大佬做完的留名,也能看到菜鸡的我,在后面~~) 直接fn+f12吧 &lt;span&gt;连接在左边→&lt;/span&gt; &lt;a href="first.php"&gt;&lt;/a&gt; &lt;span&gt;←连接在右边&lt;/span&gt; o...
在家远程办公效率低?那你一定要收好这个「在家办公」神器!
相信大家都已经收到国务院延长春节假期的消息,接下来,在家远程办公可能将会持续一段时间。 但是问题来了。远程办公不是人在电脑前就当坐班了,相反,对于沟通效率,文件协作,以及信息安全都有着极高的要求。有着非常多的挑战,比如: 1在异地互相不见面的会议上,如何提高沟通效率? 2文件之间的来往反馈如何做到及时性?如何保证信息安全? 3如何规划安排每天工作,以及如何进行成果验收? ...... ...
作为一个程序员,内存和磁盘的这些事情,你不得不知道啊!!!
截止目前,我已经分享了如下几篇文章: 一个程序在计算机中是如何运行的?超级干货!!! 作为一个程序员,CPU的这些硬核知识你必须会! 作为一个程序员,内存的这些硬核知识你必须懂! 这些知识可以说是我们之前都不太重视的基础知识,可能大家在上大学的时候都学习过了,但是嘞,当时由于老师讲解的没那么有趣,又加上这些知识本身就比较枯燥,所以嘞,大家当初几乎等于没学。 再说啦,学习这些,也看不出来有什么用啊!...
2020年的1月,我辞掉了我的第一份工作
其实,这篇文章,我应该早点写的,毕竟现在已经2月份了。不过一些其它原因,或者是我的惰性、还有一些迷茫的念头,让自己迟迟没有试着写一点东西,记录下,或者说是总结下自己前3年的工作上的经历、学习的过程。 我自己知道的,在写自己的博客方面,我的文笔很一般,非技术类的文章不想去写;另外我又是一个还比较热衷于技术的人,而平常复杂一点的东西,如果想写文章写的清楚点,是需要足够...
别低估自己的直觉,也别高估自己的智商
所有群全部吵翻天,朋友圈全部沦陷,公众号疯狂转发。这两周没怎么发原创,只发新闻,可能有人注意到了。我不是懒,是文章写了却没发,因为大家的关注力始终在这次的疫情上面,发了也没人看。当然,我...
这个世界上人真的分三六九等,你信吗?
偶然间,在知乎上看到一个问题 一时间,勾起了我深深的回忆。 以前在厂里打过两次工,做过家教,干过辅导班,做过中介。零下几度的晚上,贴过广告,满脸、满手地长冻疮。 再回首那段岁月,虽然苦,但让我学会了坚持和忍耐。让我明白了,在这个世界上,无论环境多么的恶劣,只要心存希望,星星之火,亦可燎原。 下文是原回答,希望能对你能有所启发。 如果我说,这个世界上人真的分三六九等,...
节后首个工作日,企业们集体开晨会让钉钉挂了
By 超神经场景描述:昨天 2 月 3 日,是大部分城市号召远程工作的第一天,全国有接近 2 亿人在家开始远程办公,钉钉上也有超过 1000 万家企业活跃起来。关键词:十一出行 人脸...
Java基础知识点梳理
虽然已经在实际工作中经常与java打交道,但是一直没系统地对java这门语言进行梳理和总结,掌握的知识也比较零散。恰好利用这段时间重新认识下java,并对一些常见的语法和知识点做个总结与回顾,一方面为了加深印象,方便后面查阅,一方面为了掌握好Android打下基础。
2020年全新Java学习路线图,含配套视频,学完即为中级Java程序员!!
新的一年来临,突如其来的疫情打破了平静的生活! 在家的你是否很无聊,如果无聊就来学习吧! 世上只有一种投资只赚不赔,那就是学习!!! 传智播客于2020年升级了Java学习线路图,硬核升级,免费放送! 学完你就是中级程序员,能更快一步找到工作! 一、Java基础 JavaSE基础是Java中级程序员的起点,是帮助你从小白到懂得编程的必经之路。 在Java基础板块中有6个子模块的学...
B 站上有哪些很好的学习资源?
哇说起B站,在小九眼里就是宝藏般的存在,放年假宅在家时一天刷6、7个小时不在话下,更别提今年的跨年晚会,我简直是跪着看完的!! 最早大家聚在在B站是为了追番,再后来我在上面刷欧美新歌和漂亮小姐姐的舞蹈视频,最近两年我和周围的朋友们已经把B站当作学习教室了,而且学习成本还免费,真是个励志的好平台ヽ(.◕ฺˇд ˇ◕ฺ;)ノ 下面我们就来盘点一下B站上优质的学习资源: 综合类 Oeasy: 综合...
如何优雅地打印一个Java对象?
你好呀,我是沉默王二,一个和黄家驹一样身高,和刘德华一样颜值的程序员。虽然已经写了十多年的 Java 代码,但仍然觉得自己是个菜鸟(请允许我惭愧一下)。 在一个月黑风高的夜晚,我思前想后,觉得再也不能这么蹉跎下去了。于是痛下决心,准备通过输出的方式倒逼输入,以此来修炼自己的内功,从而进阶成为一名真正意义上的大神。与此同时,希望这些文章能够帮助到更多的读者,让大家在学习的路上不再寂寞、空虚和冷。 ...
雷火神山直播超两亿,Web播放器事件监听是怎么实现的?
Web播放器解决了在手机浏览器和PC浏览器上播放音视频数据的问题,让视音频内容可以不依赖用户安装App,就能进行播放以及在社交平台进行传播。在视频业务大数据平台中,播放数据的统计分析非常重要,所以Web播放器在使用过程中,需要对其内部的数据进行收集并上报至服务端,此时,就需要对发生在其内部的一些播放行为进行事件监听。 那么Web播放器事件监听是怎么实现的呢? 01 监听事件明细表 名...
【CSDN学院出品】 你不可不知的JS面试题(分期更新……)
1、JS中有哪些内置类型? 7种。分别是boolean、number、string、object、undefined、null、symbol。 2、NaN是独立的一种类型吗? 不是。NaN是number类型。 3、如何判断是哪个类型? Object.prototype.toString.call(),返回为[object Type]。 现在我们来验证一下。 Object.prototype.toS...
3万字总结,Mysql优化之精髓
本文知识点较多,篇幅较长,请耐心学习 MySQL已经成为时下关系型数据库产品的中坚力量,备受互联网大厂的青睐,出门面试想进BAT,想拿高工资,不会点MySQL优化知识,拿offer的成功率会大大下降。 为什么要优化 系统的吞吐量瓶颈往往出现在数据库的访问速度上 随着应用程序的运行,数据库的中的数据会越来越多,处理时间会相应变慢 数据是存放在磁盘上的,读写速度无法和内存相比 如何优化 设计...
HTML5适合的情人节礼物有纪念日期功能
前言 利用HTML5,css,js实现爱心树 以及 纪念日期的功能 网页有播放音乐功能 以及打字倾诉感情的画面,非常适合情人节送给女朋友 具体的HTML代码 具体只要修改代码里面的男某某和女某某 文字段也可自行修改,还有代码下半部分的JS代码需要修改一下起始日期 注意月份为0~11月 也就是月份需要减一。 当然只有一部分HTML和JS代码不够运行的,文章最下面还附加了完整代码的下载地址 &lt;!...
Git笔记(3) 安装配置
Git的安装,基础配置以及如何获取帮助
Python新型冠状病毒疫情数据自动爬取+统计+发送报告+数据屏幕(三)发送篇
今天介绍的项目是使用 Itchat 发送统计报告 项目功能设计: 定时爬取疫情数据存入Mysql 进行数据分析制作疫情报告 使用itchat给亲人朋友发送分析报告 基于Django做数据屏幕 使用Tableau做数据分析 来看看最终效果 目前已经完成,预计2月12日前更新 使用 itchat 发送数据统计报告 itchat 是一个基于 web微信的一个框架,但微信官方并不允许使用这...
Java中国银行系统ATM机自助实现登录、开户、存款、取款、转账、查询余额、修改预留手机号、注销账号等功能(Ziph)
@Java 最全功能的银行ATM机自助(严谨性) 大家好,我是Ziph! 此小项目的体会真是,为了实现功能是不择手段啊,为了实现和完善功能,码了一遍又一遍(找Bug),测试了N多次功能,测试好了发个博。OK,点个赞呗!哈哈,废话少说向下看吧! 题目: 中国银行系统ATM机自助实现登录、开户、存款、取款、转账、查询余额、修改预留手机号、注销账号等功能 此小项目主要是运用了增删改查知识、循环结构知识、...
给Python初学者的一些编程技巧
这篇文章主要介绍了给Python初学者的一些编程技巧,皆是基于基础的一些编程习惯建议,需要的朋友可以参考下 交换变量 x = 6 y = 5 x, y = y, x print x &gt;&gt;&gt; 5 print y &gt;&gt;&gt; 6 if 语句在行内 print "Hello" if True else "World" &gt;&gt;&gt; Hello ...
相关热词 c# 为空 判断 委托 c#记事本颜色 c# 系统默认声音 js中调用c#方法参数 c#引入dll文件报错 c#根据名称实例化 c#从邮件服务器获取邮件 c# 保存文件夹 c#代码打包引用 c# 压缩效率
立即提问