ajax 请求到后台参数为null 10C
 $.ajax({
            type: "post",
            async: false,
            cache: false,
            dataType:"json",
            contentType: false,
            processData:false,
            traditional: true, //使json格式的字符串不会被转码
            url: "${ctx}/grouppurchase/add",
            data: {
                 name: $("[name='name']").val(),
                 sbegin:$("#userStartDate").val()+" 00:00:00",
                 send:$("[name='send']").val()+" 00:00:00",
                 gbegin:$("[name='gbegin']").val()+" 00:00:00",
                 gend: $("[name='gend']").val()+" 00:00:00",
                 price: $("[name='price']").val(),
                 tprice:$("[name='tprice']").val(),
                 num: $("[name='num']").val(),
                 refund:refund,
                 appointment:appointment,
                 img:formdata,
                 context:editor.txt.html(),
                 storeid:strgetSelectValue,
            },
            success: function (data) {
                alert("成功")
            },
            error: function (XMLHttpRequest, textStatus, errorThrown) {
                alert("提交失败,错误代码:" + XMLHttpRequest.status);
                alert("提交失败,错误代码:" + XMLHttpRequest.readyState);
                alert("提交失败,错误代码:" + textStatus);
            }
        });

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

17个回答

你后台代码的requestparam注解写了两个context

dataType 改成text

看看前台数据类型与后台数据类型,是否一致,要一致才能取到

tjj3027
三知之灵 回复温酒不说谎: 有些数据不一致,并且数据类型不能强制转换是会报错的
大约 2 年之前 回复
erhuaxiama
erhuaxiama dataType 改成text
大约 2 年之前 回复
weixin_40915647
温酒不说谎 一个不一致会导致全部都为null么?
大约 2 年之前 回复

url: "${ctx}/grouppurchase/add", 这个add是方法名把?把 @RequestMapping("/add")加到@Responsebody 上面试试

发送的请求参数没有传递过去。。

前台获取到了吗?打印出来看一下;获取到了后台我写法跟你不一样,你可以试下:
@RequestMapping(value = "/add", method = RequestMethod.POST, produces = "text/html;charset=UTF-8")
@ResponseBody
public String add(HttpServletRequest request, HttpServletResponse response,
ModelMap map) {
//我感觉有request直接获取参数就好了,当然,你用@RequestParam就少了判断少参数情况时的判断
String name = request.getParameter("name");
...

        }

Controller加注解了嘛?

这么多个参数,建议使用对象接收就行了

@RequestBody 替换掉@requestparam

参数好多啊,不如用对象呢

共17条数据 1 尾页
Csdn user default icon
上传中...
上传图片
插入图片
抄袭、复制答案,以达到刷声望分或其他目的的行为,在CSDN问答是严格禁止的,一经发现立刻封号。是时候展现真正的技术了!
其他相关推荐
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();
前台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") } ``` 解决了的问答不知道怎么下掉,看到这问答的伙伴们路过就可以了。
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; }
input如何通过ajax获取后台的数据
后台sql查询的数据,怎么通过ajax传到前台的input ``` $(function() { $.ajax({ type : 'post', url : 'xxx.action', dataType : 'json', data : { 'Id' : $('#Id').val() }, success : function(data) { if(data != null && data.length > 0){ } }, error : function() { $.message.alert('提示', '请求失败!', 'error'); } }); }); ``` if里面应该写些什么内容呢
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向后台请求数据时执行error不执行success
<script type="text/javascript"> $(function() { $("input[name=uname]").blur(function() { var name = $(this).val(); if(name==null||name==""){ $("#yid span").html("用户名不能为空"); }else{ $.ajax({ "url" : "RegistServlet", "type" : "get", "data" : "name="+name, "dataType" : "text", "success" : function(result) { $("#yid span").html(result); }, error: function(){ alert("报错了"); } }); } }); }) </script>
jquery ajax前台通过json格式往后台传数据 后台对象接到的老是null
<div class="iteye-blog-content-contain" style="font-size: 14px;"> <p>前台的 静态json数据</p> <p>var resContactInfos1 = [{ </p> <p>metadataId: '001',</p> <p>orgCode:'001',</p> <p>orgName: 'zhangsan', </p> <p>address: '20', </p> <p>            email: 'shanghai' </p> <p>        }, </p> <p>        { </p> <p>        metadataId: '002', </p> <p>        orgCode: '002', </p> <p>        orgName: 'beijing', </p> <p>        address: '21', </p> <p>        email: 'beijing' </p> <p>        } </p> <p>        ]; </p> <p>ajax 请求 </p> <p>var data1={resContactInfo:resContactInfos1};</p> <p>$.ajax({</p> <p>          url: "rc/resourceCatalogManagerAction!saveResource.action", //后台处理的地址</p> <p>          type: "POST",</p> <p>          contentType: "application/json",</p> <p>          data: JSON.stringify(data1),</p> <p>          success:function(){</p> <p>         alert("success");</p> <p>          }</p> <p>});</p> <p> 后台action</p> <p>private list&lt;ResContactInfo&gt;resContactInfo;</p> <p>后台有个resContactInfo属性 它的get set方法也写了 </p> <p>ResContactInfo这个类的属性为 metadataId 、orgCode等 同上面的json对象中的5个属性</p> <p> </p> <p>问题  :我看到浏览器发的请求 感觉是没有问题的  但是后台显示接不到值  求解???</p> <p style="font-size: 14px; line-height: 21px;"> </p> <p> </p> <p> </p> <p> </p> </div>
jenkins部署项目成功以后,ajax访问后台不返回数据
用jenkins部署公司的项目,部署成功以后,访问登陆页面可以,输入用户名和密码登陆以后,就前台报错。但是用eclipse启动项目就可以正常的登陆进去。为什么呢?求大佬帮忙解决一下。请求后台操作是用ajax写的。报下面的错误,是不是jenkins和ajax冲突或者其他原因。 前台报 Uncaught TypeError: Cannot read property 'success' of null 这个错误
select2 ajax获取java后台下拉框数据 并回显选中的值
用ajax 请求后台值后 发现 下拉框没有搜索功能了 ![图片说明](https://img-ask.csdn.net/upload/201808/05/1533440496_530669.png) ``` * 执行select2方法初始化 */ function select2Execute() { var dataList = [ { id: 0, text: 'enhancement' }, { id: 1, text: 'bug' }, { id: 2, text: 'duplicate' }, { id: 3, text: 'invalid' }, { id: 4, text: 'wontfix' } ]; var dataList1=[{'id':"1","text":"enhancement"}]; $(function() { /*本地注入方式*/ $(".downList2").select2({ // $("select[name='xuewei_id']").select2({ // $('select[id="xuewei_id"]').select2({ // $('#xuewei_id').select2({ // $("#selectSection").find("select.combox").select2({ // $(".select2-selection__choice").select2(); // $(".combox").select2({ placeholder : "请至少选择一个人名", tags : true, createTag : function(decorated, params) { return null; }, width : '256px', ajax: { url: '/erzhentang/manage/forAjax.do?requestType=12.5_1', dataType: 'json', data: function (params) { var query = { //请求的参数, 关键字和搜索条件之类的 search: params.term //select搜索框里面的value } // Query paramters will be ?search=[term]&page=[page] return query; }, delay: 250, processResults: function (data, params) { //返回的选项必须处理成以下格式 var results = [{ id: 0, text: 'enhancement' }, { id: 1, text: 'bug' }, { id: 2, text: 'duplicate' }, { id: 3, text: 'invalid' }, { id: 4, text: 'wontfix' }]; return { results: results //必须赋值给results并且必须返回一个obj }; } }, allowClear: true,//允许清空 escapeMarkup: function (markup) { return markup; }, // 自定义格式化防止xss注入 minimumInputLength: 0, formatResult: function formatRepo(repo){return repo.text;}, // 函数用来渲染结果 formatSelection: function formatRepoSelection(repo){return repo.text;} // 函数用于呈现当前的选择 }); //two AJAX获取数据方式 //$("select[name='xuewei_id']").select2({ /*$(".downList2").select2({ ajax: { type:'GET', url: '/erzhentang/manage/forAjax.do?requestType=12.5_1', // url: dataList1, dataType: 'json', delay: 250, data: function (params) { return { q: params.term, // search term 请求参数 page: params.page }; }, processResults: function (data, params) { params.page = params.page || 1; var itemList = []; var arr = data.result.list for(item in arr){ itemList.push({id: item, text: arr[item]}) } var itemList = []; var results = [{ id: 0, text: 'enhancement' }, { id: 1, text: 'bug' }, { id: 2, text: 'duplicate' }, { id: 3, text: 'invalid' }, { id: 4, text: 'wontfix' }]; var arr = result.list for(item in arr){ itemList.push({id: item, text: arr[item]}) } var results = [{ id: 0, text: 'enhancement' }, { id: 1, text: 'bug' }, { id: 2, text: 'duplicate' }, { id: 3, text: 'invalid' }, { id: 4, text: 'wontfix' }]; // var results=[{"id":"68","text":"平和质"},{"id":"104","text":"特禀质"}] return { // results: data.items,//itemList results: results , //必须赋值给results并且必须返回一个obj // results: data,//itemList pagination: { more: (params.page * 2) < data.total_count } }; }, cache: true }, placeholder:'请选择',//默认文字提示 language: "zh-CN", tags: true,//允许手动添加 allowClear: true,//允许清空 escapeMarkup: function (markup) { return markup; }, // 自定义格式化防止xss注入 minimumInputLength: 0, formatResult: function formatRepo(repo){return repo.text;}, // 函数用来渲染结果 formatSelection: function formatRepoSelection(repo){return repo.text;} // 函数用于呈现当前的选择 });*/ function formatState(state) { if (!state.id) { return state.text; } var $state = $('<span>' + state.text + '</span>'); return $state; } ; $('#sel_recommender').select2({ placeholder : "请选择一个人名", templateResult : formatState, width : '256px' }); // 通过id获取select2的text值,这里的text值可能有空格,需注意 function getSelect2Text(obj) { var select2Obj = $("select[name='xuewei_id']").select2(); return select2Obj.find("option:selected").text(); } /* 获取每一个name对应的值 */ var strXueweiId = ""; $("[name=xuewei_id]").each(function() { alert("this值:" + $(this).val()); /* 拼接每一项name的值 组合成和其它项目类似 gender那样的数组 */ strXueweiId += $(this).val() + "-"; }); alert("strXueweiId:" + strXueweiId) $("#strXueweiId").val(strXueweiId) }); } ```
前台发ajax,后台返回json,有数据!前台获取不到,试了好久
前台请求 ``` $.ajax({ //提交类型 type:"post", //提交url url:"/SSM1/tologin", //提交的数据 data:{uid:$("#name").val(),upwd:$("#pwd").val()}, //返回数据格式 datatype:"json", //成功返回调用的函数 success:function(data){ alert(data); }, //调用出错执行的函数 error:function(data){ alert(data); } }); ``` 后台代码 ``` @ResponseBody @RequestMapping(value="/tologin",method= RequestMethod.POST) public void tologin(@RequestParam("uid") String uid,@RequestParam("upwd")String upwd ,HttpServletResponse response) throws IOException{ // 解决后台返回数据给前台出现的乱码问题 //response.setContentType("text/javascript;charset=utf-8"); response.setContentType("application/json;charset=utf-8"); response.setCharacterEncoding("UTF-8"); //信息处理类 Result result = new Result(); //根据id查询是否存在该用户 TbUser user=userservice.findById(uid); //如果存在判断密码 if(user!=null) { String pwd=user.getUpwd(); if(pwd.equals(upwd)) { result.setMsg("账号密码正确"); result.setCode(1);//1正确 result.setSuccess(true);//true成功正确 }else { result.setMsg("密码错误"); result.setCode(-2);//-2密码错误 result.setSuccess(false); } }else { result.setMsg("账号不存在"); result.setCode(-1);//-1失败 result.setSuccess(false); } JSONObject jsonObject=new JSONObject(); jsonObject.put("result", result); response.getWriter().print(jsonObject); ); } ``` 请求获得的数据 ![图片说明](https://img-ask.csdn.net/upload/201905/18/1558144723_84297.jpg) ![图片说明](https://img-ask.csdn.net/upload/201905/18/1558144737_833629.jpg) ![图片说明](https://img-ask.csdn.net/upload/201905/18/1558144723_84297.jpg) 其实有值的,只是弹窗显示的是object,object ![图片说明](https://img-ask.csdn.net/upload/201905/20/1558332115_576203.jpg)
Java的封装类型和原始类型的区别?那种性能好?
Java的封装类型和原始类型的区别?在JavaWeb程序当中,pojo(javabean)实体类中,是声明为封装类型好还是原始类型好?(比如:int-Integer) 例如: public class User{ private int id; private Integer id1; } int 默认初始化为0;Integer初始化为null; 如果在web前端通过ajax请求到后台的时候,参数传递为 id=&di1= 后台获取参数值时: id=1 id1=null 然后,保存到数据库时,Integer是不是要拆包为int类型? 请问声明为那种类型更好,更适合程序的处理和性能? 请问各位Java大神分析分析,求指导!
select2 ajax 获取java后台数据 提示params is not defined
下拉框没有任何选项内容 ![图片说明](https://img-ask.csdn.net/upload/201808/05/1533410857_939033.png) js代码 ``` /* 执行select2方法初始化 */ function select2Execute() { var dataList = [ { id: 0, text: 'enhancement' }, { id: 1, text: 'bug' }, { id: 2, text: 'duplicate' }, { id: 3, text: 'invalid' }, { id: 4, text: 'wontfix' } ]; var dataList1=[{'id':"1","text":"enhancement"}]; $(function() { /*本地注入方式*/ /*$("select[name='xuewei_id']").select2({ // $('select[id="xuewei_id"]').select2({ // $('#xuewei_id').select2({ // $("#selectSection").find("select.combox").select2({ // $(".select2-selection__choice").select2(); // $(".combox").select2({ placeholder : "请至少选择一个人名", tags : true, createTag : function(decorated, params) { return null; }, width : '256px', });*/ //two AJAX获取数据方式 //$("select[name='xuewei_id']").select2({ $(".downList2").select2({ ajax: { type:'GET', // url: '/erzhentang/manage/forAjax.do?requestType=12.1', url: dataList1, dataType: 'json', delay: 250, data: function (params) { return { q: params.term, // search term 请求参数 page: params.page }; }, processResults: function (data, params) { params.page = params.page || 1; /*var itemList = []; var arr = data.result.list for(item in arr){ itemList.push({id: item, text: arr[item]}) }*/ return { results: data.items,//itemList pagination: { more: (params.page * 2) < data.total_count } }; }, cache: true }, placeholder:'请选择',//默认文字提示 language: "zh-CN", tags: true,//允许手动添加 allowClear: true,//允许清空 escapeMarkup: function (markup) { return markup; }, // 自定义格式化防止xss注入 minimumInputLength: 0, formatResult: function formatRepo(repo){return repo.text;}, // 函数用来渲染结果 formatSelection: function formatRepoSelection(repo){return repo.text;} // 函数用于呈现当前的选择 }); function formatState(state) { if (!state.id) { return state.text; } var $state = $('<span>' + state.text + '</span>'); return $state; } ; $('#sel_recommender').select2({ placeholder : "请选择一个人名", templateResult : formatState, width : '256px' }); // 通过id获取select2的text值,这里的text值可能有空格,需注意 function getSelect2Text(obj) { var select2Obj = $("select[name='xuewei_id']").select2(); return select2Obj.find("option:selected").text(); } /* 获取每一个name对应的值 */ var strXueweiId = ""; $("[name=xuewei_id]").each(function() { alert("this值:" + $(this).val()); /* 拼接每一项name的值 组合成和其它项目类似 gender那样的数组 */ strXueweiId += $(this).val() + "-"; }); alert("strXueweiId:" + strXueweiId) $("#strXueweiId").val(strXueweiId) }); } ```
vue中echarts图无法渲染
我在父组件中定义了一个容器,然后定义了echarts图的基本配置项,在created中调用一个方法,获取后台数据,然后将数据传递到子组件中渲染echarts图,现在数据都能成功传递,但是一直无法成功渲染echarts图 以下为父组件代码 ``` // 父组件代码 <template> <div> <div class="leftChart"> <linegraph :id="'leftChart'" :data="option1" style="height:330px;width:100%"></linegraph> </div> </div> </template> <script> // 引入子组件 import linegraph from "./EchartsShow.vue"; // 引入网络请求方法 import { getSumData } from "@/api/crd/orgLimitView/orgView" export default { data () { return { // echarts图基本配置项,未定义具体数据 option1: { title: { text: '授信额度结构', subtext: '行业维度', x: 'center', top: '3%' }, tooltip: { trigger: 'item', formatter: "{a} <br/>{b} : {c} ({d}%)" }, legend: { orient: 'vertical', left: '2%', top: '2%' }, series: [ { name: '行业', type: 'pie', radius: '55%', center: ['50%', '55%'], itemStyle: { emphasis: { shadowBlur: 10, shadowOffsetX: 0, shadowColor: 'rgba(0, 0, 0, 0.5)' } } } ] }, } }, created () { this.getSum() }, methods: { getSum () { // 调用get请求方法,获取后台数据,由于进度问题,目前只能传递固定的参数,才能获取到测试数据 getSumData('1', '01000').then(res => { if (res.status != 200) { return this.$message.error('获取数据失败,请重试') } const datas = res.data.data // 由于拿到的数据非常复杂繁多,需要进行一些处理,才能拿到需要的数据 this.option1.legend.data = this.tableDatas.map(item => { // 由于后台拿到的数据,都是数字类的码值,this.dicInd[item.industry] 用来翻译后台数据 return this.dicInd[item.industry] }) this.option1.series[0].data = this.tableDatas.map(item => { return { value: item.approveExpAmount, name: this.dicInd[item.industry] } }) console.log(this.option1.legend.data, '行业'); console.log(this.option1.series[0].data, '行业带数据'); }) } }, components: { linegraph } } </script> ``` 以下为子组件代码 ``` // 子组件代码 <template> <div v-bind:id="id" v-bind:data="data"></div> </template> <script> import echarts from "echarts"; export default { name: "echartsShow", data () { return { ChartLineGraph: null }; }, // 深度监听 父组件刚开始没有值,只有图标的配置项 // 父组件ajax请求后改变数据的值,传递过来,图标已生成,监听传过来的值的改变 watch: { data: { deep: true, handler: function (newVal, oldVal) { if (newvalue) { this.drawLineGraph(this.id, newVal) } else { this.drawLineGraph(this.id, oldVal) } } } }, props: ["id", "data"], created() { console.log(this.data, '打印传递过来的图表数据') }, mounted () { this.drawLineGraph(this.id, this.data); console.log(this.id, '打印id值') console.log(this.data, '打印data值') }, methods: { drawLineGraph (id, data) { let _this = this; let myChart = document.getElementById(id); this.ChartLineGraph = echarts.init(myChart); this.ChartLineGraph.setOption(data); window.addEventListener("resize", function () { _this.ChartLineGraph.resize(); }); } }, beforeDestroy () { if (this.ChartLineGraph) { this.ChartLineGraph.clear(); } } }; </script> ``` 从后台获取数据后,成功传递给子组件,但是echarts无法成功渲染 ![图片说明](https://img-ask.csdn.net/upload/202001/07/1578384445_959195.png) ![图片说明](https://img-ask.csdn.net/upload/202001/07/1578384684_683561.png) ![图片说明](https://img-ask.csdn.net/upload/202001/07/1578384616_880352.png) ![图片说明](https://img-ask.csdn.net/upload/202001/07/1578384792_786796.png) 经过多次尝试,我遇到了一个奇怪的问题 ![图片说明](https://img-ask.csdn.net/upload/202001/07/1578385072_241075.png) ![图片说明](https://img-ask.csdn.net/upload/202001/07/1578385147_470918.png) 求各位大佬指点,我的代码哪个地方写错了,如何才能成功渲染echarts
ajax post提交到action无法获取json数据
从前台请求数据确保是传过去了,但是后台就是无法获取到,跪求大神指导啊 ![图片说明](https://img-ask.csdn.net/upload/201707/12/1499848761_863838.png) jsp代码如下: $("#but").click(function(){ var name=$("#name").val(); $.ajax({ type:"post", url:"/ajaxtest/ajax/ajaxtest.action", data:{ name:name }, contentType:"application/json;charset=utf-8", success : function(data) { alert(data); if(data!=null){ var myData = eval("(" + data+")"); alert(myData.info); }else{ alert("数据异常"); } }, dataType:"json" }); }); Struts代码: <package name="ajax" namespace="/ajax" extends="json-default"> <action name="ajaxtest" class="ajax.action.AjaxAction" method="ajaxtest"> <result name="success">/index.jsp</result> </action> </package> action代码: public class AjaxAction extends ActionSupport{ private static final long serialVersionUID = 1L; private String name; public String ajaxtest(){ System.out.println(name); return SUCCESS; } public String getName() { return name; } public void setName(String name) { this.name = name; } }
Ajax 与 Servlet 之间通信问题
Ajax主要请求代码: function showHint() { xmlHttp=GetXmlHttpObject() if (xmlHttp==null) { alert ("Ajax not support"); return; } var url="syncsendtocp"; xmlHttp.onreadystatechange=stateChanged; xmlHttp.open("GET",url,true); xmlHttp.send(null); } 通过window.setInterval('showHint()', 6000);进行定时执行 SyncSendToCP HttpServlet响应代码 public void doGet(HttpServletRequest req, HttpServletResponse resp){ try{ PrintWriter pw=resp.getWriter(); pw.println(change); pw.flush(); pw.close(); }catch(Exception e){ e.printStackTrace(); } } web配置文件 <servlet> <servlet-name>SyncSendToCP</servlet-name> <servlet-class>com.openlab.publicopinion.struts.action.SyncSendToCP</servlet-class> <init-param> <param-name>debug</param-name> <param-value>0</param-value> </init-param> <load-on-startup>1</load-on-startup> </servlet> 遇到的问题是这样,第一次Ajax执行到后台查询数据的时候,SyncSendToCP的DoGet方法能正常响应,但是Ajax循环执行到第二次以及以后的时候,SyncSendToCP的DoGet方法根本没有响应,感觉像是没有获取到这个Get请求,是为什么呀?
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"; }
关于Spring boot + SpringSecurity +jwt token失效的问题
比如我登abc的用户,然后我在另一个地点也登abc的用户,那前一个登陆的在刷新或者请求接口的时候要登出, 或者是我后台改了abc的密码,那abc这个账户在刷新请求接口的时候要登出。 框架我搭好了 代码如下: 生成token工具类: ``` public class JwtTokenUtil { private static InputStream inputStream = Thread.currentThread().getContextClassLoader().getResourceAsStream("jwt.jks"); // 寻找证书文件 private static PrivateKey privateKey = null; private static PublicKey publicKey = null; static { // 将证书文件里边的私钥公钥拿出来 try { KeyStore keyStore = KeyStore.getInstance("JKS"); // java key store 固定常量 keyStore.load(inputStream, "123456".toCharArray()); privateKey = (PrivateKey) keyStore.getKey("jwt", "123456".toCharArray()); // jwt 为 命令生成整数文件时的别名 publicKey = keyStore.getCertificate("jwt").getPublicKey(); } catch (Exception e) { e.printStackTrace(); } } public static String generateToken(String subject, int expirationSeconds, String salt) { return Jwts.builder() .setClaims(null) .setSubject(subject) .setExpiration(new Date(System.currentTimeMillis() + expirationSeconds * 1000)) // .signWith(SignatureAlgorithm.HS512, salt) // 不使用公钥私钥 .signWith(SignatureAlgorithm.RS256, privateKey) .compact(); } public static String parseToken(String token, String salt) { String subject = null; try { Claims claims = Jwts.parser() // .setSigningKey(salt) // 不使用公钥私钥 .setSigningKey(publicKey) .parseClaimsJws(token).getBody(); subject = claims.getSubject(); } catch (Exception e) { } return subject; } } ``` 登陆成功后生成JTWtoken : ``` @Component public class AjaxAuthenticationSuccessHandler implements AuthenticationSuccessHandler { @Override public void onAuthenticationSuccess(HttpServletRequest httpServletRequest, HttpServletResponse httpServletResponse, Authentication authentication) throws IOException, ServletException { ResponseBase responseBase = new ResponseBase(); responseBase.setCode("200"); responseBase.setMassage("Login Success!"); String jwtToken = JwtTokenUtil.generateToken(String.valueOf(authentication.getPrincipal()), 300, "_secret"); responseBase.setJwtToken(jwtToken); httpServletResponse.getWriter().write(JSON.toJSONString(responseBase)); } } ``` 监听器: ``` @Component public class JwtAuthenticationTokenFilter extends OncePerRequestFilter { @Autowired AdminSysUserSecurityService adminSysUserSecurityService; @Override protected void doFilterInternal(HttpServletRequest request, HttpServletResponse response, FilterChain chain) throws ServletException, IOException { String authHeader = request.getHeader("Authorization"); if (authHeader != null && authHeader.startsWith("Bearer ")) { final String authToken = authHeader.substring("Bearer ".length()); String username = JwtTokenUtil.parseToken(authToken, "_secret"); if (username != null && SecurityContextHolder.getContext().getAuthentication() == null) { UserDetails userDetails = adminSysUserSecurityService.loadUserByUsername(username); if (userDetails != null) { UsernamePasswordAuthenticationToken authentication = new UsernamePasswordAuthenticationToken(userDetails, null, userDetails.getAuthorities()); authentication.setDetails(new WebAuthenticationDetailsSource().buildDetails(request)); SecurityContextHolder.getContext().setAuthentication(authentication); } } } chain.doFilter(request, response); } } ``` ``` @Component("rbacauthorityservice") public class RbacAuthorityService { public boolean hasPermission(HttpServletRequest request, Authentication authentication) { Object userInfo = authentication.getPrincipal(); boolean hasPermission = false; if (userInfo instanceof UserDetails) { String username = ((UserDetails) userInfo).getUsername(); //获取资源 Set<String> urls = new HashSet(); urls.add("/**/**"); // 这些 url 都是要登录后才能访问,且其他的 url 都不能访问! Set set2 = new HashSet(); Set set3 = new HashSet(); AntPathMatcher antPathMatcher = new AntPathMatcher(); for (String url : urls) { if (antPathMatcher.match(url, request.getRequestURI())) { hasPermission = true; break; } } return hasPermission; } else { return false; } } } ``` 配置: ``` @Configuration public class AdminWebSecurityConfig extends WebSecurityConfigurerAdapter { @Value("${pay.strength}") private int strength; @Autowired private AdminSysUserSecurityService adminSysUserSecurityService; @Bean public PasswordEncoder passwordEncoder(){ // return NoOpPasswordEncoder.getInstance();//不对密码加密 return new BCryptPasswordEncoder(strength);//秘钥迭代次数为 2^strength,strength取值在 4-31 之间,默认10 } @Autowired AjaxAuthenticationEntryPoint authenticationEntryPoint; // 未登陆时返回 JSON 格式的数据给前端(否则为 html) @Autowired AjaxAuthenticationSuccessHandler authenticationSuccessHandler; // 登录成功返回的 JSON 格式数据给前端(否则为 html) @Autowired AjaxAuthenticationFailureHandler authenticationFailureHandler; // 登录失败返回的 JSON 格式数据给前端(否则为 html) @Autowired AjaxLogoutSuccessHandler logoutSuccessHandler; // 注销成功返回的 JSON 格式数据给前端(否则为 登录时的 html) @Autowired AjaxAccessDeniedHandler accessDeniedHandler; // 无权访问返回的 JSON 格式数据给前端(否则为 403 html 页面) @Autowired JwtAuthenticationTokenFilter jwtAuthenticationTokenFilter; // JWT 拦截器 @Autowired SelfAuthenticationProvider provider; // 自定义安全认证 @Override protected void configure(AuthenticationManagerBuilder auth) throws Exception { // 加入自定义的安全认证 auth.authenticationProvider(provider); } @Override public void configure(HttpSecurity http)throws Exception{ //开启HttpSecurity配置 http.csrf().disable() .sessionManagement().sessionCreationPolicy(SessionCreationPolicy.STATELESS) // 使用 JWT,关闭token .and() .httpBasic().authenticationEntryPoint(authenticationEntryPoint) .and() .authorizeRequests() // .antMatchers("/db/**").hasRole("DB") // .antMatchers("/user/**").hasRole("USER") // .antMatchers("/admin/**").hasRole("ADMIN") // .antMatchers("/user/**").access("hasAnyRole('ADMIN','ROOT')") // .antMatchers("/db/**").access("hasAnyRole('ADMIN') and hasRole('DBA')") //除了前面路径,用户访问其他URL都必须认证后访问 .anyRequest() .access("@rbacauthorityservice.hasPermission(request,authentication)") // RBAC 动态 url 认证 .and() //开启表单登录,同事配置了登入接口为/login .formLogin() /* //该接口主要方便ajax或者移动端登入 .loginProcessingUrl("/login") //设置登录成功跳转页面,error=true控制页面错误信息的展示 .successForwardUrl("/index").failureUrl("/login?error=true") */ //登入接口都不需要认证 .successHandler(authenticationSuccessHandler) // 登录成功 .failureHandler(authenticationFailureHandler) // 登录失败 .permitAll() .and() //开启注销登入配置 .logout() .logoutSuccessHandler(logoutSuccessHandler) .permitAll(); http.rememberMe().rememberMeParameter("remember-me") .userDetailsService(adminSysUserSecurityService).tokenValiditySeconds(300); http.exceptionHandling().accessDeniedHandler(accessDeniedHandler); // 无权访问 JSON 格式的数据 http.addFilterBefore(jwtAuthenticationTokenFilter, UsernamePasswordAuthenticationFilter.class); // JWT Filter } ``` 登陆成功后获取token,postman测试: ![图片说明](https://img-ask.csdn.net/upload/201912/11/1576056718_177252.png) 可以 但是我重新调用新的登陆接口,相同用户名获取新的token后,原来的token依旧可以请求。 所以要在哪边配置 用户其它地方登陆,或者用户密码变更,jtwtoken失效
ssm 框架已经实现,但是ajax返回验证有毛病
``` <%@ page language="java" contentType="text/html; charset=UTF-8" pageEncoding="UTF-8"%> <!DOCTYPE html PUBLIC "-//W3C//DTD HTML 4.01 Transitional//EN" "http://www.w3.org/TR/html4/loose.dtd"> <html> <head> <meta http-equiv="Content-Type" content="text/html; charset=UTF-8"> <title>js+ajax</title> <script type="text/javascript" src="static/bootstrap/js/jquery-2.0.3.js"></script> <script type="text/javascript"> function validate(){ var name= $("#name").val(); if(name==null||name==""){ //为空隐藏提交按钮 var ui =document.getElementById("tijiao"); ui.style.display="none"; //这里是简单的显示 不设计后台,前台做的判断 $("#namediv").html("用户名不可以为空"); }else{ //ajax实现 //11111111获取XMLhtmlRequestxml对象 var req=createXmlHttpRequest(); //222222222准备url 数据 回调函数 //这个name是function下面var的参数. var url="/maven/reg1.do?name="+name; //还有一个参数表示的是异步还是同步,一般不写直接就是true,异步的 req.open("GET",url,true); //3333333333这个就是回调函数 req.onreadystatechange=callback; //这个send是在从servlet判断你的账号是不是存在, 如果是true就说名字存在,给页面返回了以后才有的.为啥写空不知道 //4发送请求 req.send(null); //回调函数 function callback(){ //第一个是我们的服务器成功接受了响应,并且解释了出来,状态4 第二个是服务器内部没有发生错误, url什么的也没有错, if(req.readyState=4&&req.status==200){ var date=req.responseText; if(date=="false"){ //下面的是意思是,如果账号存在了,提交按钮自动消失 //超级叼 var ui =document.getElementById("tijiao"); ui.style.display="none"; $("#namediv").html("用户名已经存在"); }else{ //不为空了,按钮一直显示 var ui =document.getElementById("tijiao"); ui.style.display=""; $("#namediv").html("用户名可以使用"); } } } } } function createXmlHttpRequest(){ //如果是ie6以上版本的浏览器 if(window.XMLHttpRequest){ return new XMLHttpRequest(); }else{ //如果浏览器是ie以下的 return new ActiveXObject("Microsoft.XMLHTTP"); } } </script> </head> <body> <form action="/maven/reg1.do" id="form1"> <table id="aa"> <tr> <td>用户名</td> <td><input type="text" name="username" id="name" onblur="validate();" />&nbsp;<font color="red">*</font></td> <td> <div id="namediv" style="display: inline"></div> </td> <td>密码</td> <td><input type="password" name="password"></td> <td>电话</td> <td><input type="text" name="phone"></td> <td><input type="submit" value="点击注册" id="tijiao"></td> </tr> </table> </form> </body> </html> ``` ``` ``` ``` package com.gray.user.controller; import java.io.IOException; import java.io.PrintWriter; import javax.servlet.http.HttpServletRequest; import javax.servlet.http.HttpServletResponse; import javax.servlet.http.HttpSession; import org.springframework.beans.factory.annotation.Autowired; import org.springframework.http.HttpRequest; import org.springframework.stereotype.Controller; import org.springframework.ui.Model; import org.springframework.web.bind.annotation.RequestMapping; import org.springframework.web.bind.annotation.RequestParam; import com.gray.user.entity.RegUser; import com.gray.user.service.impl.RegServiceImpl; import com.gray.user.service.impl.UserServiceImpl; @Controller public class RegController { @Autowired private RegServiceImpl userService; //自动装载他到spring @RequestMapping("/reg1.do") //url public String dologin(Model model,HttpServletResponse res,@RequestParam String username,RegUser rg,HttpServletResponse response) throws IOException{ boolean used=false; System.out.println("测试参数获取到bean没有"+rg.getUsername()+rg.getPassword()+rg.getPhone()); rg.setUsername(username); if(userService.doUserLogin(rg)){ used=true; System.out.println("通过control到--->service---到dao---到usermapp.在返回回来,service里面是ture,就是说账号不重复"); }else{ used=false; System.out.println("通过control到--->service---到dao---到usermapp.在返回回来,service里面是false,重复了账号 "); } return "regsuccess"; } } ``` ``` package com.gray.user.service.impl; import java.util.List; import org.springframework.beans.factory.annotation.Autowired; import org.springframework.stereotype.Service; import com.gray.user.dao.UserDao; import com.gray.user.entity.RegUser; import com.gray.user.entity.User; import com.gray.user.service.RegService; import com.gray.user.service.UserService; @Service public class RegServiceImpl implements RegService { @Autowired private UserDao<RegUser> dao; @Override public boolean doUserLogin(RegUser ruser) { //第一次执行查询数据库,查询 userdao selectUserName方法。 他这个方法和user.xml里面的id为selectUserName串联了. //也就是直接调用查询语句,并且吧值返回给reguser 类 System.out.println("testRegServiceImpl------->查询数据库,查询语句为id是selectusername"); List<RegUser> list = dao.selectUserName(ruser.getUsername()); System.out.println("查到了集合大小是"+list.size()+"查到了和你账号相同是的是几个"); if(list.size() == 0){ System.out.println("RegServiceImpl---你没有查询到你账号和数据库相同的信息.所以你return,"); for(int i=0;i<list.size();i++){ System.out.println(list.get(i).getUsername()); } return true; }else{ if(list.size()!=0){ System.out.println("regServiceImpl---查询到和你相同的账号不是0个,返回false"); return false; }else{ System.out.println("regserviceImpl----其他情况我也不知道啥情况,也返回false"); return false; } } } } ``` ``` 页面上的ajax 他就一直出毛病,数据库有个账号名是aa 只有我在表单填写aa 他才在网页提示账号重复, 别的任何都不提示,只会提示不能为空, 而且还失灵时不灵。 但是用system. 输出 我写的任何判断都是对了, 这是为啥? 请求大神给我说下,最好说下哪里错了。谢谢了
bootstrap fileinput initialPreviewConfig 中参数问题
var preList = new Array(); var listImage = selectItem.FImage.split(","); var listFUrl = selectItem.FUrl; var previewJson = preList; // 与上面 预览图片json数据组 对应的config数据 var initPreviewConfig = new Array(); for ( var i = 1; i < listImage.length; i++) { var urlList = listImage[i].split(":"); preList[i]= "<img src=\""+listFUrl+urlList[0]+"\" class=\"file-preview-image\">"; /* alert(urlList[1]); var config = new Object(); config.caption = urlList[0]; config.url='deleteAssetsImage.html'; config.key=urlList[1]; config.extra = {id: urlList[1]}; initPreviewConfig.push(config);*/ var array_element = urlList[0]; var tjson = {caption: array_element, // 展示的文件名 width: '120px', url: 'deleteAssetsImage.html', // 删除url key: 100, // 删除是Ajax向后台传递的参数 extra: function() { return {id: urlList[1]}; } }; initPreviewConfig[i] = tjson; } initFileInput("projectfile", "uploadZCImage.html",selectItem.FAssetsRegiId); $("#projectfile").fileinput('refresh', { initialPreview: preList, initialPreviewConfig: initPreviewConfig }); 后台 spring @RequestMapping(value = "/deleteAssetsImage.html", method = RequestMethod.DELETE) public void deleteAssetsImage(HttpServletRequest request,HttpServletResponse response,ModelMap model) { response.setCharacterEncoding("UTF-8"); System.out.println("==========================="); try { //getPara("key"); boolean result = false; String id = (String) request.getParameter("key"); String id2 = (String) request.getParameter("id"); System.out.println(id2+"==========================="+id); if(id!=null){ result= assetsService.deleteAssetsImage(Integer.parseInt(id)); } renderText(response, result); } catch (IOException e) { // TODO Auto-generated catch block e.printStackTrace(); } } 始终获取不到参数,用POST请求会报405请求错误,求解答
终于明白阿里百度这样的大公司,为什么面试经常拿ThreadLocal考验求职者了
点击上面↑「爱开发」关注我们每晚10点,捕获技术思考和创业资源洞察什么是ThreadLocalThreadLocal是一个本地线程副本变量工具类,各个线程都拥有一份线程私...
Java学习的正确打开方式
在博主认为,对于入门级学习java的最佳学习方法莫过于视频+博客+书籍+总结,前三者博主将淋漓尽致地挥毫于这篇博客文章中,至于总结在于个人,实际上越到后面你会发现学习的最好方式就是阅读参考官方文档其次就是国内的书籍,博客次之,这又是一个层次了,这里暂时不提后面再谈。博主将为各位入门java保驾护航,各位只管冲鸭!!!上天是公平的,只要不辜负时间,时间自然不会辜负你。 何谓学习?博主所理解的学习,它是一个过程,是一个不断累积、不断沉淀、不断总结、善于传达自己的个人见解以及乐于分享的过程。
程序员必须掌握的核心算法有哪些?
由于我之前一直强调数据结构以及算法学习的重要性,所以就有一些读者经常问我,数据结构与算法应该要学习到哪个程度呢?,说实话,这个问题我不知道要怎么回答你,主要取决于你想学习到哪些程度,不过针对这个问题,我稍微总结一下我学过的算法知识点,以及我觉得值得学习的算法。这些算法与数据结构的学习大多数是零散的,并没有一本把他们全部覆盖的书籍。下面是我觉得值得学习的一些算法以及数据结构,当然,我也会整理一些看过
大学四年自学走来,这些私藏的实用工具/学习网站我贡献出来了
大学四年,看课本是不可能一直看课本的了,对于学习,特别是自学,善于搜索网上的一些资源来辅助,还是非常有必要的,下面我就把这几年私藏的各种资源,网站贡献出来给你们。主要有:电子书搜索、实用工具、在线视频学习网站、非视频学习网站、软件下载、面试/求职必备网站。 注意:文中提到的所有资源,文末我都给你整理好了,你们只管拿去,如果觉得不错,转发、分享就是最大的支持了。 一、电子书搜索 对于大部分程序员...
《奇巧淫技》系列-python!!每天早上八点自动发送天气预报邮件到QQ邮箱
将代码部署服务器,每日早上定时获取到天气数据,并发送到邮箱。 也可以说是一个小人工智障。 思路可以运用在不同地方,主要介绍的是思路。
Python 植物大战僵尸代码实现(2):植物卡片选择和种植
这篇文章要介绍的是: - 上方植物卡片栏的实现。 - 点击植物卡片,鼠标切换为植物图片。 - 鼠标移动时,判断当前在哪个方格中,并显示半透明的植物作为提示。
死磕YOLO系列,YOLOv1 的大脑、躯干和手脚
YOLO 是我非常喜欢的目标检测算法,堪称工业级的目标检测,能够达到实时的要求,它帮我解决了许多实际问题。 这就是 YOLO 的目标检测效果。它定位了图像中物体的位置,当然,也能预测物体的类别。 之前我有写博文介绍过它,但是每次重新读它的论文,我都有新的收获,为此我准备写一个系列的文章来详尽分析它。这是第一篇,从它的起始 YOLOv1 讲起。 YOLOv1 的论文地址:https://www.c
知乎高赞:中国有什么拿得出手的开源软件产品?(整理自本人原创回答)
知乎高赞:中国有什么拿得出手的开源软件产品? 在知乎上,有个问题问“中国有什么拿得出手的开源软件产品(在 GitHub 等社区受欢迎度较好的)?” 事实上,还不少呢~ 本人于2019.7.6进行了较为全面的 回答 - Bravo Yeung,获得该问题下回答中得最高赞(236赞和1枚专业勋章),对这些受欢迎的 Github 开源项目分类整理如下: 分布式计算、云平台相关工具类 1.SkyWalk
记一次腾讯面试:进程之间究竟有哪些通信方式?如何通信? ---- 告别死记硬背
有一次面试的时候,被问到进程之间有哪些通信方式,不过由于之前没深入思考且整理过,说的并不好。想必大家也都知道进程有哪些通信方式,可是我猜很多人都是靠着”背“来记忆的,所以今天的这篇文章,讲给大家详细着讲解他们是如何通信的,让大家尽量能够理解他们之间的区别、优缺点等,这样的话,以后面试官让你举例子,你也能够顺手拈来。 1、管道 我们来看一条 Linux 的语句 netstat -tulnp | gr...
20行Python代码爬取王者荣耀全英雄皮肤
引言 王者荣耀大家都玩过吧,没玩过的也应该听说过,作为时下最火的手机MOBA游戏,咳咳,好像跑题了。我们今天的重点是爬取王者荣耀所有英雄的所有皮肤,而且仅仅使用20行Python代码即可完成。 准备工作 爬取皮肤本身并不难,难点在于分析,我们首先得得到皮肤图片的url地址,话不多说,我们马上来到王者荣耀的官网: 我们点击英雄资料,然后随意地选择一位英雄,接着F12打开调试台,找到英雄原皮肤的图片
网络(8)-HTTP、Socket、TCP、UDP的区别和联系
TCP/IP协议是传输层协议,主要解决数据如何在网络中传输,而HTTP是应用层协议,主要解决如何包装数据。 一、TCP与UDP的不同 1. 是否需要建立连接。 UDP在传送数据之前不需要先建立连接;TCP则提供面向连接的服务; 2. 是否需要给出确认 对方的传输层在收到UDP报文后,不需要给出任何确认,而 TCP需要给出确认报文,要提供可靠的、面向连接的传输服务。 3.虽然UDP不提供可靠交...
简明易理解的@SpringBootApplication注解源码解析(包含面试提问)
欢迎关注文章系列 ,关注我 《提升能力,涨薪可待》 《面试知识,工作可待》 《实战演练,拒绝996》 欢迎关注我博客,原创技术文章第一时间推出 也欢迎关注公 众 号【Ccww笔记】,同时推出 如果此文对你有帮助、喜欢的话,那就点个赞呗,点个关注呗! 《提升能力,涨薪可待篇》- @SpringBootApplication注解源码解析 一、@SpringBootApplication 的作用是什
防劝退!数据结构和算法难理解?可视化动画带你轻松透彻理解!
大家好,我是 Rocky0429,一个连数据结构和算法都不会的蒟蒻… 学过数据结构和算法的都知道这玩意儿不好学,没学过的经常听到这样的说法还没学就觉得难,其实难吗?真难! 难在哪呢?当年我还是个小蒟蒻,初学数据结构和算法的时候,在忍着枯燥看完定义原理,之后想实现的时候,觉得它们的过程真的是七拐八绕,及其难受。 在简单的链表、栈和队列这些我还能靠着在草稿上写写画画理解过程,但是到了数论、图...
西游记团队中如果需要裁掉一个人,会先裁掉谁?
2019年互联网寒冬,大批企业开始裁员,下图是网上流传的一张截图: 裁员不可避免,那如何才能做到不管大环境如何变化,自身不受影响呢? 我们先来看一个有意思的故事,如果西游记取经团队需要裁员一名,会裁掉谁呢,为什么? 西游记团队组成: 1.唐僧 作为团队teamleader,有很坚韧的品性和极高的原则性,不达目的不罢休,遇到任何问题,都没有退缩过,又很得上司支持和赏识(直接得到唐太宗的任命,既给
开挂的人生!那些当选院士,又是ACM/IEEE 双料Fellow的华人学者们
昨日,2019年两院院士正式官宣,一时间抢占了各大媒体头条。 朋友圈也是一片沸腾,奔走相告,赶脚比自己中了大奖还嗨皮! 谁叫咱家导师就是这么厉害呢!!! 而就在最近,新一年度的IEEE/ACM Fellow也将正式公布。 作为学术届的顶级荣誉,不自然地就会将院士与Fellow作比较,到底哪个含金量更高呢? 学术君认为,同样是专业机构对学者的认可,考量标准不一,自然不能一概而论。 但...
聊聊C语言和指针的本质
坐着绿皮车上海到杭州,24块钱,很宽敞,在火车上非正式地聊几句。 很多编程语言都以 “没有指针” 作为自己的优势来宣传,然而,对于C语言,指针却是与生俱来的。 那么,什么是指针,为什么大家都想避开指针。 很简单, 指针就是地址,当一个地址作为一个变量存在时,它就被叫做指针,该变量的类型,自然就是指针类型。 指针的作用就是,给出一个指针,取出该指针指向地址处的值。为了理解本质,我们从计算机模型说起...
Python语言高频重点汇总
Python语言高频重点汇总 GitHub面试宝典仓库——点这里跳转 文章目录Python语言高频重点汇总**GitHub面试宝典仓库——点这里跳转**1. 函数-传参2. 元类3. @staticmethod和@classmethod两个装饰器4. 类属性和实例属性5. Python的自省6. 列表、集合、字典推导式7. Python中单下划线和双下划线8. 格式化字符串中的%和format9.
究竟你适不适合买Mac?
我清晰的记得,刚买的macbook pro回到家,开机后第一件事情,就是上了淘宝网,花了500元钱,找了一个上门维修电脑的师傅,上门给我装了一个windows系统。。。。。。 表砍我。。。 当时买mac的初衷,只是想要个固态硬盘的笔记本,用来运行一些复杂的扑克软件。而看了当时所有的SSD笔记本后,最终决定,还是买个好(xiong)看(da)的。 已经有好几个朋友问我mba怎么样了,所以今天尽量客观...
代码详解:如何用Python快速制作美观、炫酷且有深度的图表
全文共12231字,预计学习时长35分钟生活阶梯(幸福指数)与人均GDP(金钱)正相关的正则图本文将探讨三种用Python可视化数据的不同方法。以可视化《2019年世界幸福报告》的数据为例,本文用Gapminder和Wikipedia的信息丰富了《世界幸福报告》数据,以探索新的数据关系和可视化方法。《世界幸福报告》试图回答世界范围内影响幸福的因素。报告根据对“坎特里尔阶梯问题”的回答来确定幸...
程序员一般通过什么途径接私活?
二哥,你好,我想知道一般程序猿都如何接私活,我也想接,能告诉我一些方法吗? 上面是一个读者“烦不烦”问我的一个问题。其实不止是“烦不烦”,还有很多读者问过我类似这样的问题。 我接的私活不算多,挣到的钱也没有多少,加起来不到 20W。说实话,这个数目说出来我是有点心虚的,毕竟太少了,大家轻喷。但我想,恰好配得上“一般程序员”这个称号啊。毕竟苍蝇再小也是肉,我也算是有经验的人了。 唾弃接私活、做外...
(经验分享)作为一名普通本科计算机专业学生,我大学四年到底走了多少弯路
今年正式步入了大四,离毕业也只剩半年多的时间,回想一下大学四年,感觉自己走了不少弯路,今天就来分享一下自己大学的学习经历,也希望其他人能不要走我走错的路。 (一)初进校园 刚进入大学的时候自己完全就相信了高中老师的话:“进入大学你们就轻松了”。因此在大一的时候自己学习的激情早就被抛地一干二净,每天不是在寝室里玩游戏就是出门游玩,不过好在自己大学时买的第一台笔记本性能并不是很好,也没让我彻底沉...
如何写一篇技术博客,谈谈我的看法
前言 只有光头才能变强。 文本已收录至我的GitHub精选文章,欢迎Star:https://github.com/ZhongFuCheng3y/3y 我一直推崇学技术可以写技术博客去沉淀自己的知识,因为知识点实在是太多太多了,通过自己的博客可以帮助自己快速回顾自己学过的东西。 我最开始的时候也是只记笔记,认为自己能看得懂就好。但如果想验证自己是不是懂了,可以写成技术博客。在写技术博客的...
字节跳动面试官这样问消息队列:分布式事务、重复消费、顺序消费,我整理了一下
你知道的越多,你不知道的越多 点赞再看,养成习惯 GitHub上已经开源 https://github.com/JavaFamily 有一线大厂面试点脑图、个人联系方式和人才交流群,欢迎Star和完善 前言 消息队列在互联网技术存储方面使用如此广泛,几乎所有的后端技术面试官都要在消息队列的使用和原理方面对小伙伴们进行360°的刁难。 作为一个在互联网公司面一次拿一次Offer的面霸...
面试还搞不懂redis,快看看这40道面试题(含答案和思维导图)
Redis 面试题 1、什么是 Redis?. 2、Redis 的数据类型? 3、使用 Redis 有哪些好处? 4、Redis 相比 Memcached 有哪些优势? 5、Memcache 与 Redis 的区别都有哪些? 6、Redis 是单进程单线程的? 7、一个字符串类型的值能存储最大容量是多少? 8、Redis 的持久化机制是什么?各自的优缺点? 9、Redis 常见性...
大学四年自学走来,这些珍藏的「实用工具/学习网站」我全贡献出来了
知乎高赞:文中列举了互联网一线大厂程序员都在用的工具集合,涉及面非常广,小白和老手都可以进来看看,或许有新收获。
互联网公司的裁员,能玩出多少种花样?
裁员,也是一门学问,可谓博大精深!以下,是互联网公司的裁员的多种方法:-正文开始-135岁+不予续签的理由:千禧一代网感更强。95后不予通过试用期的理由:已婚已育员工更有责任心。2通知接下来要过苦日子,让一部分不肯同甘共苦的员工自己走人,以“兄弟”和“非兄弟”来区别员工。3强制996。员工如果平衡不了工作和家庭,可在离婚或离职里二选一。4不布置任何工作,但下班前必须提交千字工作日报。5不给活干+...
【设计模式】单例模式的八种写法分析
网上泛滥流传单例模式的写法种类,有说7种的,也有说6种的,当然也不排除说5种的,他们说的有错吗?其实没有对与错,刨根问底,写法终究是写法,其本质精髓大体一致!因此完全没必要去追究写法的多少,有这个时间还不如跟着宜春去网吧偷耳机、去田里抓青蛙得了,一天天的....
《面试宝典》:检验是否为合格的初中级程序员的面试知识点,你都知道了吗?查漏补缺
欢迎关注文章系列,一起学习 《提升能力,涨薪可待篇》 《面试知识,工作可待篇》 《实战演练,拒绝996篇》 也欢迎关注公 众 号【Ccww笔记】,原创技术文章第一时间推出 如果此文对你有帮助、喜欢的话,那就点个赞呗,点个关注呗! 《面试知识,工作可待篇》-Java笔试面试基础知识大全 前言 是不是感觉找工作面试是那么难呢? 在找工作面试应在学习的基础进行总结面试知识点,工作也指日可待,欢...
关于研发效能提升的思考
研发效能提升是最近比较热门的一个话题,本人根据这几年的工作心得,做了一些思考总结,由于个人深度有限,暂且抛转引入。 三要素 任何生产力的提升都离不开这三个因素:人、流程和工具,少了其中任何一个因素都无法实现。 人,即思想,也就是古人说的“道”,道不同不相为谋,是制高点,也是高层建筑的基石。 流程,即方法,也是古人说的“法”。研发效能的提升,也就是要提高投入产出比,既要增加产出,也要减...
微博推荐算法简述
在介绍微博推荐算法之前,我们先聊一聊推荐系统和推荐算法。有这样一些问题:推荐系统适用哪些场景?用来解决什么问题、具有怎样的价值?效果如何衡量? 推荐系统诞生很早,但真正被大家所重视,缘起于以”facebook”为代表的社会化网络的兴起和以“淘宝“为代表的电商的繁荣,”选择“的时代已经来临,信息和物品的极大丰富,让用户如浩瀚宇宙中的小点,无所适从。推荐系统迎来爆发的机会,变得离用户更近: 快...
相关热词 c#怎么获得线程名 c# usb 采集器 c# csv 读取 c# sort() c# 关闭io流 c# 响应函数 插入 c#面对对象的三大特性 c# 打印 等比缩放 c#弹出右键菜单 c#1如何搞成01
立即提问