执行页面出现 HTTP Status 500

description The server encountered an internal error that prevented it from fulfilling this request.

exception
java.lang.NullPointerException
com.dao.BooksDao.selBookByPage(BooksDao.java:30)
com.servlet.IndexServlet.doPost(IndexServlet.java:70)
com.servlet.IndexServlet.doGet(IndexServlet.java:25)
javax.servlet.http.HttpServlet.service(HttpServlet.java:620)
javax.servlet.http.HttpServlet.service(HttpServlet.java:727)
org.apache.tomcat.websocket.server.WsFilter.doFilter(WsFilter.java:52)
com.filter.EncodeFilter.doFilter(EncodeFilter.java:24)
note The full stack trace of the root cause is available in the Apache Tomcat/7.0.57 logs.
错误页面出现这个情况,怎么解决呢
求大神们帮助

3个回答

报500是说服务器出了问题,从你的报错信息来看是产生了空指针异常,也就是一个对象还没有实例化就使用报错信息中给出了两个个文件:BooksDao.java、IndexServlet.java按照给出的代码行数去看是哪个对象没有实例化,把它实例化就好了

java.lang.NullPointerException
com.dao.BooksDao.selBookByPage(BooksDao.java:30)
com.servlet.IndexServlet.doPost(IndexServlet.java:70)
com.servlet.IndexServlet.doGet(IndexServlet.java:25)

500表示服务器运行异常
这几行分别表示 空指针异常,booksdao.java第30行出错向上抛出异常,indexservlet.java第70行抛异常,IndexServlet.java:25第25行抛异常。
后两个是因为dao运行时有了异常抛出来的不用管,就看booksdao30行什么变量空了,你没贴具体代码所以不知道到底什么情况

500服务器报错,com.dao.BooksDao.selBookByPage(BooksDao.java:30)这个类的30行报了空指针错误,你可以在获取数据那里做个判断

Csdn user default icon
上传中...
上传图片
插入图片
抄袭、复制答案,以达到刷声望分或其他目的的行为,在CSDN问答是严格禁止的,一经发现立刻封号。是时候展现真正的技术了!
其他相关推荐
vue项目,在切换路由时内存没有释放,再次切换回原路由或者是其他页面,为什么内存又被释放了?
先说一下环境:vue:2.5.2 vue-router:3.0.1 element-ui:2.13.0 最开始存在三个页面HelloWorld、foo和bar。 分别说一下这两个页面都有什么: HelloWorld页面,有一个请求(会请求一些数据),将请求回来的数据放到data中,并用element-ui的select组件进行展示,另外就是一个跳转至foo页面的按钮,代码如下: ``` <template> <div class="hello"> <el-button @click="getAccountListPage"> page获取科目列表 </el-button> <el-select v-model="activeAcc" placeholder="请选择"> <el-option v-for="item in accountPageList" :key="item.id" :label="item.codeAndName" :value="item.id"> </el-option> </el-select> <el-button @click="goToFoo"> go Foo </el-button> </div> </template> <script> export default { name: 'HelloWorld', data () { return { activeAcc: '', accountPageList: [] } }, methods: { getAccountListPage() { let xmlhttp, that = this; if (window.XMLHttpRequest) { // IE7+, Firefox, Chrome, Opera, Safari 浏览器执行代码 xmlhttp=new XMLHttpRequest(); } else { // IE6, IE5 浏览器执行代码 xmlhttp=new ActiveXObject("Microsoft.XMLHTTP"); } xmlhttp.onreadystatechange=function() { if (xmlhttp.readyState==4 && xmlhttp.status==200) { let res = JSON.parse(xmlhttp.response); if(res.result) { that.accountPageList = res.value; } } }; xmlhttp.open("POST","******这里是url*******",true); xmlhttp.setRequestHeader("Content-type","application/json"); xmlhttp.send('{}'); }, goToFoo() { this.$router.push({name: 'foo'}) } }, } </script> <!-- Add "scoped" attribute to limit CSS to this component only --> <style scoped></style> ``` foo页面,很简单,有一个跳转至HelloWorld页面的按钮和一个跳转至bar页面的按钮,代码如下: ``` <template> <div class="foo"> 这是Foo页面 <el-button @click="goToHelloWorld"> go HelloWorld </el-button> <el-button @click="goToBar"> go Bar </el-button> </div> </template> <script> export default { name: 'Foo', data () { return {} }, computed: {}, methods: { goToHelloWorld() { this.$router.push({name: 'HelloWorld'}) }, goToBar() { this.$router.push({name: 'bar'}) } } } </script> <!-- Add "scoped" attribute to limit CSS to this component only --> <style scoped></style> ``` bar页面和foo页面一样,有一个跳转至HelloWorld页面的按钮和一个跳转至foo页面的按钮,代码如下: ``` <template> <div class="bar"> 这是Bar页面 <el-button @click="goToHelloWorld"> go HelloWorld </el-button> <el-button @click="goToFoo"> go Foo </el-button> </div> </template> <script> export default { name: 'Bar', data () { return { } }, computed: {}, methods: { goToHelloWorld() { this.$router.push({name: 'HelloWorld'}) }, goToFoo() { this.$router.push({name: 'foo'}) } }, } </script> <!-- Add "scoped" attribute to limit CSS to this component only --> <style scoped></style> ``` 操作步骤: 1.进入HelloWord页面,不做任何操作,利用chrome浏览器开发者工具中的Performance monitor工具,查看内存使用情况 ![图片说明](https://img-ask.csdn.net/upload/201912/31/1577778311_366832.png) 2.点击按钮获取数据,查看内存 ![图片说明](https://img-ask.csdn.net/upload/201912/31/1577778454_982794.png) 可以看到,js、dom nodes、 js event,都有所增加。 3.跳转至foo页面,查看内存 ![图片说明](https://img-ask.csdn.net/upload/201912/31/1577778614_138117.png) 这时候发现内存占用情况并没有明显变化,也就是说跳转foo页面后,helloword页面的内存并未得到释放。这是问题一。 4.这时候跳转至bar页面,查看内存 ![图片说明](https://img-ask.csdn.net/upload/201912/31/1577778782_257327.png) 可以看到,刚刚存在的内存占用已经被释放了。这是问题二。 上面的截图都是我手动垃圾回收(collect garbage)后的截图。 对于上面出现的两个问题,还请各位大佬解答一下,万分感谢!!!
servlet 过滤器 错误代码http status 404
我做了一个解决中文乱码的过滤器代码是这样的: package com.app.encoding; import java.io.IOException; import javax.servlet.FilterChain; import javax.servlet.FilterConfig; import javax.servlet.ServletException; import javax.servlet.ServletRequest; import javax.servlet.ServletResponse; class EncodingFilter implements javax.servlet.Filter { private String encoding; public void destroy() { // TODO Auto-generated method stub } public void doFilter(ServletRequest request, ServletResponse response, FilterChain chain) throws IOException, ServletException { // TODO Auto-generated method stub request.setCharacterEncoding("GBK"); chain.doFilter(request, response); } public void init(FilterConfig filterConfig) throws ServletException { // TODO Auto-generated method stub encoding = filterConfig.getInitParameter("encoding"); } } web.xml的配置 <filter> <description>解决中文乱码</description> <filter-name>EncodingFilter</filter-name> <filter-class>com.app.encoding.EncodingFilter</filter-class> <init-param> <param-name>encoding</param-name> <param-value>GBK</param-value> </init-param> </filter> <filter-mapping> <filter-name>EncodingFilter</filter-name> <url-pattern>/*</url-pattern> </filter-mapping> 没有写过滤器之前执行tomcat是能出现页面的,就是有中文乱码,但是加了过滤器之后就出现了 HTTP Status 404 The requested resource is not available. 弄了快一个上午了,还是搞不明白是哪里错误了,网上说路径错误,但是我检查了都没问题的,谢谢啦
ajaxSubmit提交数据到后台为什么不执行success方法,只执行error方法
求大神解惑!!!!数据可以插入到数据库中,但是回调函数只执行error不执行success 页面js代码如下 var v = $('#myForm').validate({ submitHandler: function (form) { var date = $("#myForm").serialize(); //这里是jquery表单验证通过的时候执行的操作,比如这里,表单验证通过的时候执行了jquery的ajax的post操作 $(form).ajaxSubmit({ url:'addUser', date:date, type:'POST', dataType:'json', clearForm:true, resetForm:true, success : function(responseText,statusText){ if(responseText.status == "0"){ /** * 请求成功后的操作 */ alert('保存成功'); } else { alert('保存失败'); } }, error : function(xhr,status,err) { alert(xhr.responseText); alert(status); debugger; } }); } }); 后台action代码 @Action(value = "addUser") public void addUser(){ userInfoService.insertUser(userInfo); message = "success"; try { PrintWriter writer = response.getWriter(); writer.write(message); writer.flush(); writer.close(); } catch (IOException e) { e.printStackTrace(); } }
求助ajax执行后,会自动刷新页面,该如何阻止?
asp.net mvc 前台代码: ``` <html> <head> <meta name="viewport" content="width=device-width" /> <title>TestUpload</title> <script type="text/javascript" src="~/Scripts/jquery-1.10.2.min.js"></script> </head> <body> <div> <textarea id="txt"></textarea> <form id="uploadForm" action="Upload/TestAjax" method="post" enctype="multipart/form-data"> <input id="File1" name="fileupload" accept="image/gif, image/jpeg" multiple="multiple" type="file" value="" /> <input id="btn" type="button" value="上传" /> </form> </div> </body> </html> <script type="text/javascript"> $(function () { $("#btn").click(function () { var formData = new FormData($("#uploadForm")[0]); //var formData = $("#uploadForm"); $.ajax({ url: "/Upload/TestAjax", data: formData, type: "POST", cache: false, async: true, contentType: false, processData: false, success: function (data) { console.log(data); }, error: function (data) { console.log(data); }, }); return false; }); }); </script> ``` 后台代码 ``` public ActionResult TestUpload() { return View(); } [HttpPost] public ActionResult TestAjax() { if (Request.Files.Count > 0) { if (Request.Files.Count == 1) { HttpPostedFileBase file = Request.Files[0]; if (file.ContentLength > 0) { string title = string.Empty; title = DateTime.Now.Ticks.ToString() + Path.GetExtension(file.FileName); string path = "/upload/" + DateTime.Now.ToString("yyyyMMdd")+"/" + title; path = System.Web.HttpContext.Current.Server.MapPath(path); file.SaveAs(path); return Json(new { status = true, url = path }); } } else { string[] urllist = new string[Request.Files.Count]; for (int i = 0; i < Request.Files.Count; i++) { HttpPostedFileBase file = Request.Files[i]; if (file.ContentLength > 0) { string title = string.Empty; title = DateTime.Now.Ticks.ToString() +Path.GetExtension(file.FileName); string path = "/upload/" + DateTime.Now.ToString("yyyyMMdd") + "/" + title; path = System.Web.HttpContext.Current.Server.MapPath(path); file.SaveAs(path); urllist[i] = path; } } return Json(new { status = true, url = urllist }); } } else { return Json(new { status = false, url = "", msg = "没有文件" }); } return Json(new { status = false, url = "", msg = "" }); } ``` 其实就是一个简单的ajax文件上传。我的要求是,执行成功不要刷新页面。 但是很奇怪的是,执行不成功时,代码不刷新,一旦执行成功就自动给我刷新了!!!跪求各位大大 开发环境WIN10+VS2015
用ArcGIS JavaScript api怎样将GP服务的执行结果(栅格数据)添加到页面上
我的GP 服务是对遥感影像进行水体信息提取,gp服功能能够实现,可是在将结果添加到页面时却不能实现, gp.getResultImageLayer(jobInfo.jobId, "water", imageParams, function (gpLayer) { gpLayer.setOpacity(0.5); map.addLayer(gpLayer); });这句代码总是不能实现求个为前辈帮帮忙,谢谢! ``` <!DOCTYPE html> <html> <head> <meta http-equiv="Content-Type" content="text/html; charset=utf-8"> <meta http-equiv="X-UA-Compatible" content="IE=7, IE=9"> <meta name="viewport" content="width=device-width,user-scalable=no"> <!--The viewport meta tag is used to improve the presentation and behavior of the samples on iOS devices--> <meta name="viewport" content="initial-scale=1, maximum-scale=1,user-scalable=no"> <title>影像处理系统</title> <link rel="stylesheet" type="text/css" href="http://localhost:8080/arcgis_js_api/library/3.3/jsapi/js/dojo/dijit/themes/tundra/tundra.css"/> <link rel="stylesheet" type="text/css" href="http://localhost:8080/arcgis_js_api/library/3.3/jsapi/js/esri/css/esri.css" /> <link rel="stylesheet" href="http://localhost:8080/arcgis_js_api/library/3.3/js/dojo/dijit/themes/claro/claro.css"> <style> html, body { height: 100%; width: 100%; margin: 0; padding: 0; } </style> <script>var dojoConfig = { parseOnLoad: true // 解析加载 };</script> <script src="http://localhost:8080/arcgis_js_api/library/3.3/jsapi/init.js"></script> <script> dojo.require("dijit.layout.BorderContainer"); dojo.require("dijit.layout.ContentPane"); dojo.require("esri.map"); dojo.require("esri.toolbars.draw"); dojo.require("esri.tasks.gp"); var map, toolbar, gp; function init() { map = new esri.Map("map"); basemap = new esri.layers.ArcGISDynamicMapServiceLayer("http://localhost:6080/arcgis/rest/services/LZC/MyMapService/MapServer"); map.addLayer(basemap); dojo.connect(map, 'onLoad', createToolbar); } //选取水体提取范围 function drawPolygon1() { alert("请选择提取范围!"); flge=1; toolbar.activate(esri.toolbars.Draw.POLYGON); } //选取植被提取范围 function drawPolygon2() { alert("请选择提取范围!"); flge=2; toolbar.activate(esri.toolbars.Draw.POLYGON); } //绘制裁剪范围 function createToolbar(themap) { dojo.connect(dijit.byId('map'), 'resize', map, map.resize); toolbar = new esri.toolbars.Draw(map); // esri.toolbars.Draw(map, options) dojo.connect(toolbar, "onDrawEnd", drawEnd); // 绘制完成触发 } //定义裁剪范围symbol function drawEnd(geometry) { toolbar.deactivate(); var symbol = new esri.symbol.SimpleFillSymbol(esri.symbol.SimpleFillSymbol.STYLE_SOLID, new esri.symbol.SimpleLineSymbol(esri.symbol.SimpleLineSymbol.STYLE_DASHDOT, new dojo.Color([255, 0, 0]), 2), new dojo.Color([255, 255, 0, 0.25])); var graphic = new esri.Graphic(geometry, symbol); map.graphics.add(graphic); tojob(graphic); } //传递参数以及调用服务 function tojob(graphic) { //第一步构造GP var gpUrl ="http://localhost:6080/arcgis/rest/services/GPP/water/GPServer/water"; gp = new esri.tasks.Geoprocessor(gpUrl); //第二步,构造参数 //我们通过上面,了解到GPFeatureRecordSetLayer对应FeatureSet var features = []; features.push(graphic); var featureset = new esri.tasks.FeatureSet(); featureset.features = features; var parms = { polygon : featureset }; //这里函数是异步的,使用函数是submitJob,同步的使用的是execute。 //成功之后,调用jobResult,建议看一下这个参数。 gp.submitJob(parms, jobResult); } function jobResult(result){ var jobId = result.jobId; var status = result.jobStatus; if (status === esri.tasks.JobInfo.STATUS_SUCCEEDED) { //成功之后,将其中的结果取出来,当然这也是参数名字。 //在模型中,想要取出中间结果,需要设置为模型参数 alert("调用成功"); gp.getResultData(jobId, "water", completeCallback1); } } //添加最后提取结果 function completeCallback1(jobInfo){ imageParams = new esri.layers.ImageParameters(); imageParams.format = "tif"; imageParams.imageSpatialReference = new esri.SpatialReference({wkid: 4326}); imageParams.layerOption = esri.layers.ImageParameters.LAYER_OPTION_SHOW; alert("准备添加结果!"); gp.getResultImageLayer(jobInfo.jobId, "water", imageParams, function(gpLayer){ gpLayer.setOpacity(0.5); map.addLayer(gpLayer); }); alert("添加成功!"); } dojo.addOnLoad(init); </script> </head> <body class="tundra"> <div id="mainWindow" data-dojo-type="dijit.layout.BorderContainer" data-dojo-props="design:'headline'" style="width:100%; height:100%;"> <div id="header" data-dojo-type="dijit.layout.ContentPane" data-dojo-props="region:'right'" style="width:20%; height:100%;"> <span>功能<br/></span> <hr> <input id="Button1" type="button" value="提取水体信息" onclick="drawPolygon1()" /><br><br> <input id="Button2" type="button" value="提取植被信息" onclick="drawPolygon2()" /> <hr/> <div id="bookmark" > </div> <hr/> 图例: <div id="legendDiv" style=" height:500px; overflow:auto; border:1px solid #000000;"></div></div> <div id="map" data-dojo-type="dijit.layout.ContentPane" data-dojo-props="region:'left'" style="width:77.8%; height:100%;"> <div id="scaleBarDiv" > </div></div> </div> </body> </html> ```
shiro 不执行授权方法 doGetAuthorizationInfo()
# ShiroDbRealm.java 代码如下 ``` public class ShiroDbRealm extends AuthorizingRealm { @Resource private UserService userService; /** * 认证回调函数,登录时调用. */ @Override protected AuthenticationInfo doGetAuthenticationInfo(AuthenticationToken authcToken) throws AuthenticationException { UsernamePasswordToken token = (UsernamePasswordToken) authcToken; User currentUser = userService.findByUserName(token.getUsername()); if (currentUser != null) { if (currentUser.getStatus()==User.STATUS_DISABLED) { throw new DisabledAccountException("用户已注销"); }else if(currentUser.getStatus()==User.STATUS_NOT_ACTIVE){ throw new DisabledAccountException("用户未激活");//这里需要编写一个用户未激活异常 } return new SimpleAuthenticationInfo(currentUser.getUsername(),currentUser.getUserpwd(), ""); } return null; } /** * 授权查询回调函数, 进行鉴权但缓存中无用户的授权信息时调用. */ @Override protected AuthorizationInfo doGetAuthorizationInfo( PrincipalCollection principals) { // Cache<Object, AuthenticationInfo> authenticationCache = // getAuthenticationCache(); String primaryPrincipal = (String) principals.getPrimaryPrincipal(); System.out.println("-----------*************************------------>"+ primaryPrincipal); List<String> roles = new ArrayList<String>(); List<String> permissions = new ArrayList<String>(); SimpleAuthorizationInfo info = new SimpleAuthorizationInfo(); User user = userService.findByUserName(primaryPrincipal); if(user != null){ for (Role role : user.getRoles()) { roles.add(role.getName()); for (Permission p : role.getPermissions()) { permissions.add(p.getPrivilege()); } } }else{ throw new AuthorizationException(); } //给当前用户设置角色 info.addRoles(roles); //给当前用户设置权限 info.addStringPermissions(permissions); return info; } } ``` # applicationContext-shiro.xml配置 ``` <beans xmlns="http://www.springframework.org/schema/beans" xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance" xsi:schemaLocation=" http://www.springframework.org/schema/beans http://www.springframework.org/schema/beans/spring-beans-3.2.xsd"> <description>Shiro安全配置</description> <!-- Shiro's main business-tier object for web-enabled applications --> <bean id="securityManager" class="org.apache.shiro.web.mgt.DefaultWebSecurityManager"> <property name="realm" ref="shiroDbRealm"/> <property name="cacheManager" ref="shiroEhcacheManager"/> </bean> <!-- 項目自定义的Realm --> <bean id="shiroDbRealm" class="com.wsq.app.service.common.ShiroDbRealm"> <!-- <property name="userService" ref="userService"/> 这里我在项目中只用了注解注入--> </bean> <!-- Shiro Filter --> <bean id="shiroFilter" class="org.apache.shiro.spring.web.ShiroFilterFactoryBean"> <!-- 这个属性是必须的 --> <property name="securityManager" ref="securityManager"/> <!-- 没有登录的用户请求需要登录的页面时自动跳转到登录页面,不是必须的属性,不输入地址的话会自动寻找项目web项目的根目录下的”/login.jsp”页面 --> <property name="loginUrl" value="/login"/> <!-- 登录成功默认跳转页面,不配置则跳转至”/”。如果登陆前点击的一个需要登录的页面,则在登录自动跳转到那个需要登录的页面。不跳转到此 --> <property name="successUrl" value="/"/> <!-- 没有权限默认跳转的页面 --> <property name="unauthorizedUrl" value=""/> <!-- 就是需要验证的地址的列表,常用的包含anon、authc、perms、roles、user、logout。 --> <property name="filterChainDefinitions"> <value> /static/** = anon /login = anon /login/** = anon /logout = user /** = authc </value> </property> </bean> <!-- 用户授权信息Cache, 采用EhCache --> <bean id="shiroEhcacheManager" class="org.apache.shiro.cache.ehcache.EhCacheManager"> <property name="cacheManagerConfigFile" value="classpath:resource/ehcache-shiro.xml"/> </bean> <!-- 保证实现了Shiro内部lifecycle函数的bean执行 --> <bean id="lifecycleBeanPostProcessor" class="org.apache.shiro.spring.LifecycleBeanPostProcessor"/> <!-- AOP式方法级权限检查 --> <bean class="org.springframework.aop.framework.autoproxy.DefaultAdvisorAutoProxyCreator" depends-on="lifecycleBeanPostProcessor"> <property name="proxyTargetClass" value="true"/> </bean> <bean class="org.apache.shiro.spring.security.interceptor.AuthorizationAttributeSourceAdvisor"> <property name="securityManager" ref="securityManager"/> </bean> </beans> ``` # web.xml配置 ``` <!-- Shiro Security filter --> <filter> <filter-name>shiroFilter</filter-name> <filter-class>org.springframework.web.filter.DelegatingFilterProxy</filter-class> </filter> <filter-mapping> <filter-name>shiroFilter</filter-name> <url-pattern>/*</url-pattern> </filter-mapping> ``` 集成以后,项目可以正常启动,登陆时也可以正常调用登录验证,可就是在验证授权时,不掉用。求解答~也没分了,不好意思。
scrapy 抓取的页面只返回<h1>403 Forbidden</h1>
[问题描述](http://bbs.csdn.net/topics/392008778 "") 执行"scrapy crawl scrapyProject" 该命令后,正常运行,response.status=200,但是抓取不到页面的任何内容,返回的内容只有<h1>403 Forbidden</h1><hr>nginx/1.8.1</hr> 实在是因为囊肿羞涩,请各位高手大牛们不要介意!
java支付宝接口,支付成功以后异步通知和同步返回不执行
![图片说明](https://img-ask.csdn.net/upload/201506/17/1434519174_549941.png)java支付宝接口成功跳转到了支付宝页面,支付成功以后异步通知和同步返回不执行 网页集成支付宝接口,支付成功以后,异步通知和同步返回不执行 配置文件部分代码: public static String log_path = "D:\\aliPayLog\\"; /** * 字符编码格式 目前支持 gbk 或 utf-8 */ public static String input_charset = "utf-8"; /** * 签名方式 不需修改 */ public static String sign_type = "MD5"; /** * 服务器异步通知页面路径 */ public static final String notifyUrl = "localhost:8087/AliPay/Notify"; /** * 同步通知页面路径 */ public static final String returnUrl = "localhost:8087/AliPay/Return"; /** * 支付类型 */ public static final String paymentType = "1"; controller部分代码: @RequestMapping(value = "/Notify") public void NotifyUrl(HttpServletRequest request, HttpServletResponse response) throws ParseException { PrintWriter out = null; try { out = response.getWriter(); boolean isTrue = GetAliPayReturn(request); if (isTrue) out.write("success"); else out.write("fail"); } catch (IOException e) { e.printStackTrace(); } } @RequestMapping(value = "/Return") public String ReturnUrl(HttpServletRequest request) throws UnsupportedEncodingException, ParseException { boolean isTrue = GetAliPayReturn(request); if (isTrue) return "redirect:/center/myOrder"; // 我的订单 else return "redirect: /alipay/alipayErr"; } private boolean GetAliPayReturn(HttpServletRequest request) throws UnsupportedEncodingException, ParseException { Map<String, String> params = new HashMap<String, String>(); Map requestParams = request.getParameterMap(); for (Iterator<String> iter = requestParams.keySet().iterator(); iter.hasNext();) { String name = (String) iter.next(); ​ String[] values = (String[]) requestParams.get(name); String valueStr = ""; for (int i = 0; i < values.length; i++) { valueStr = (i == values.length - 1) ? valueStr + values[i] : valueStr + values[i] + ","; } // 乱码解决,这段代码在出现乱码时使用。如果mysign和sign不相等也可以使用这段代码转化 // valueStr = new String(valueStr.getBytes("ISO-8859-1"), "UTF-8"); if (valueStr != null && !"".equals(valueStr)) { if (!(java.nio.charset.Charset.forName("GBK").newEncoder().canEncode(valueStr))) { try { valueStr = new String(valueStr.getBytes("ISO-8859-1"), "UTF-8"); } catch (Exception e) { e.printStackTrace(); } } } params.put(name, valueStr); } boolean verify_result = AlipayNotify.verify(params); if (verify_result) { // 订单id String ID = params.get("extra_common_param"); // 订单编号 String order_id = params.get("out_trade_no"); // 支付宝交易号 String tradeNo = params.get("trade_no"); // 交易状态 String payStatus = params.get("trade_status"); StringBuilder strSql = new StringBuilder(); strSql.append("UPDATE t_order "); // 获得订单id if (payStatus.equals("TRADE_FINISHED")) { strSql.append("set order_status = 3 "); } else if (payStatus.equals("TRADE_SUCCESS")) { strSql.append("set order_status = 3 "); } else { strSql.append("set order_status = 4 "); } strSql.append(" where order_number = '" + order_id + "' "); Statement stmt = null; Connection conn = null; try { String driver = "com.mysql.jdbc.Driver"; // 驱动程序名 String url = "jdbc:mysql://192.168.1.252:3306/travel?characterEncoding=UTF-8"; // URL指向要访问的数据库名scutcs String user = "root"; // MySQL配置时的用户名 String password = "mysql"; // MySQL配置时的密码 Class.forName(driver); // 加载驱动程序 conn = DriverManager.getConnection(url, user, password); // 连续数据库 stmt = conn.createStatement(); stmt.execute(strSql.toString()); return true; } catch (Exception e) { e.printStackTrace(); } finally { try { conn.close(); stmt.close(); } catch (SQLException e) { e.printStackTrace(); } } } return false; }
C#如何将combobox里面我选择的项和表内的一个数值比对,如果相符则进入对应的页面。
我们数据库课程设计做学生成绩管理系统。 我现在在做登录界面的代码,对应的表结构是user_name,user_pwd,status遇到了一个问题:就是只要我输入的用户名和密码正确,在combobox里面选择管理员就进入管理员页面,选择学生就进入了学生页面。表里面的status是标注这个账号是什么角色,想在代码里加上一个条件就是希望能将combobox里面我选择的项和表内的status比对,如果相符则进入对应的页面。 下面是我登录部分的代码: public bool CheckInput() { bool flag=false; if(string.IsNullOrEmpty(this.用户名.Text.Trim())) { MessageBox.Show("用户名不能为空,登录失败","提示",MessageBoxButtons.OK,MessageBoxIcon.Error); } else if(string.IsNullOrEmpty(this.密码.Text.Trim())) { MessageBox.Show("密码不能为空,登录失败","提示",MessageBoxButtons.OK,MessageBoxIcon.Error); } else { flag=true; } return flag; } /// <summary> /// 登录按钮点击事件 /// </summary> /// <param name="sender"></param> /// <param name="e"></param> private void 登录_Click(object sender, EventArgs e) { if (CheckInput()) { //无密码建立连接SQL数据库对象 string connStr = "Data Source=PC-20140923RVHL\\SQL2005;Initial Catalog=Stu_mark_MS;Integrated Security=True"; //创建数据库连接对象 SqlConnection conn = new SqlConnection(connStr); try { //打开数据库连接 conn.Open(); //创建SQL语句 string sql = "select user_name,user_pwd,status from user_info where user_name='" + 用户名.Text + "'and user_pwd='" + 密码.Text + "'"; //创建命令对象 SqlCommand comm = new SqlCommand(sql, conn);//执行SQL命令 comm.CommandText = sql; comm.Connection = conn; SqlDataReader ada = comm.ExecuteReader(); if (ada.Read()) { if (this.身份.SelectedItem.ToString() == "管理员"&& status=="管理员") { //创建管理员信息窗体实例 admin admin = new admin(); //打开管理员信息窗体 admin.Show(); } if (this.身份.SelectedItem.ToString() == "学生") { //创建学生信息窗体实例 student student = new student(); //打开学生信息窗体 student.Show(); } } else { MessageBox.Show("用户名密码有误,请重新输入"); } } catch (Exception ex) { MessageBox.Show("出现异常:" + ex.Message); } finally { conn.Close(); } }
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":"验证成功"}
微信的h5页面 ajax 请求后 一直走error
**手机端 请求** 请求发送后台 请求参数后台接受到了,而且返回参数发送了,但是ajax一直在走error而不是success 1.url地址是对的 2.返回参数是json格式 3.参数后台接收到了并且参数正确 4. XMLHttpRequest.status=0, XMLHttpRequest.readyState=0, textStatus=error ``` $.ajax({ async: false, cache: false, type:"post", url: "http://192.168.0.128:8080/zhifushouquan/zhufu/wxPay", data: { userinfo:code, code:storeId, manySum:money, version:1, productContent:"微信核销", system:1 }, dataType: "json", error: function(XMLHttpRequest, textStatus, errorThrown) { alert("付款提交失败,错误代码:"+XMLHttpRequest.status); alert("付款提交失败,错误代码:"+XMLHttpRequest.readyState); alert("付款提交失败,错误代码:"+textStatus); }, success: function(data) { alert(data.return_msg.state); } }) ``` 后台代码 ![图片说明](https://img-ask.csdn.net/upload/201801/04/1515042803_113223.png) 最终执行 ![图片说明](https://img-ask.csdn.net/upload/201801/04/1515042855_291176.png)
easyui 执行新增操作jsp页面报错
后端使用SpringMVC,前端执行新增操作出问题: TypeError: $.fn.form.methods[_3de] is not a function ![图片说明](https://img-ask.csdn.net/upload/201711/05/1509865159_436782.png) js代码如下: function saveAdd(){ $.messager.confirm('提示', '您确认要提交吗?', function(r) { if (!r) { return; } $('#wangdianAddForm').form('submit', { onSubmit : function() { return $(this).form('enableValidation').form('validate'); } }); var gsmc = $("#gsmc").textbox("getValue"); var xsddm = $("#xsddm").textbox("getValue"); var xsdmc = $("#xsdmc").textbox("getValue"); var wdmc = $("#wdmc").textbox("getValue"); var wdno = $ ("#wdno").textbox("getValue"); var wdlx = $("#wdlx").textbox("getValue"); var wdlb = $("#wdlb").textbox("getValue"); var qydm = $("#qydm").textbox("getValue"); var qy = $("#qy").textbox("getValue"); var sfen = $ ("#sfen").textbox("getValue"); var cshi = $("#cshi").textbox("getValue"); var xian = $("#xian").textbox("getValue"); var xzhen = $ ("#xzhen").textbox("getValue"); var dizhi = $ ("#dizhi").textbox("getValue"); var zmdbh = $ ("#zmdbh").textbox("getValue"); var dmxz = $ ("#dmxz").textbox("getValue"); var zmdgm = $("#zmdgm").textbox("getValue"); var zspl = $("#zspl").textbox("getValue"); var jdsj = $("#jdsj").datebox("getValue"); var qczx = $("#qczx").datebox("getValue"); var zxzx = $("#zxzx").datebox("getValue"); var yb = $("#yb").textbox("getValue"); var sccj = $("#sccj").textbox("getValue"); var xsgsfy = $("#xsgsfy").textbox("getValue"); var jsxfy =$("#jsxfy").textbox("getValue"); var fzren = $("#fzren").textbox("getValue"); var bgdh = $("#bgdh").textbox("getValue"); var fzrmobile = $("#fzrmobile").textbox("getValue"); var zxfg = $("#zxfg").textbox("getValue"); var gznr = $("#gznr").textbox("getValue"); var xsry = $ ("#xsry").textbox("getValue"); var shry = $("#shry").textbox("getValue"); var qtry = $("#qtry").textbox("getValue"); var dmmj = $("#dmmj").textbox("getValue"); var bgmj = $ ("#bgmj").textbox("getValue"); var ckmj = $("#ckmj").textbox("getValue"); var sq = $ ("#sq").textbox("getValue"); var zblj = $("#zblj").textbox("getValue"); var czren = $("#czren").textbox("getValue"); var czrmc = $ ("czrmc").textbox("getValue"); var zjczren = $("#zjczren").textbox("getValue"); var zjczrmc = $("#zjczrmc").textbox("getValue"); var wangdian = { "gsmc":gsmc, "xsddm":xsddm, "xsdmc":xsdmc, "wdmc":wdmc, "wdno":wdno, "wdlx": wdlx, "wdlb": wdlb, "qydm": qydm, "qy": qy, "sfen": sfen, "cshi":cshi, "xian":xian, "xzhen":xzhen, "dizhi":dizhi, "zmdbh":zmdbh, "dmxz": dmxz, "zmdgm": zmdgm, "zspl":zspl, "jdsj":jdsj, "qczx":qczx, "zxzx":zxzx, "yb":yb, "sccj":sccj, "xsgsfy":xsgsfy, "jxsfy":jxsfy, "fzren":fzren, "bgdh":bgdh, "fzrmobile":fzrmobile, "zxfg":zxfg, "gznr":gznr, "xsry":xsry, "shry":shry, "qtry":qtry, "dmmj":dmmj, "bgmj":bgmj, "ckmj":ckmj, "sq":sq, "zblj":zblj, "czren":czren, "czrmc":czrmc, "zjczren": zjczren, "zjczrmc":zjczrmc, }; $.ajax({ type : "POST", url : "wangdianadd.do", data : wangdian, dataType : "json", success : function(data) { if (1 == data.result) { $.messager.alert("操作提示", data.msg, 'info'); $("#dlg").dialog('close'); $("#wangdianAdd_dg").datagrid("reload"); } else { $.messager.alert("操作提示", data.msg, 'info'); } }, error : function(XMLHttpRequest, textStatus, errorThrown) { $.messager.alert("操作提示", XMLHttpRequest.status + ":" + XMLHttpRequest.responseText, 'info'); } }); }); } 是Jquery.js的问题还是我的代码的问题。
求解决No Hibernate Session bound to thread
ssh项目在运行时控制台没有出错,但是页面出现 HTTP Status 500 - No Hibernate Session bound to thread, and configuration does not allow creation of non-transactional one here怎么解决??? ![图片说明](https://img-ask.csdn.net/upload/201503/18/1426660994_104397.jpg) applicationContext.xml文件配置如下: <?xml version="1.0" encoding="UTF-8"?> <beans xmlns="http://www.springframework.org/schema/beans" xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance" xmlns:context="http://www.springframework.org/schema/context" xmlns:aop="http://www.springframework.org/schema/aop" xmlns:tx="http://www.springframework.org/schema/tx" xsi:schemaLocation="http://www.springframework.org/schema/beans http://www.springframework.org/schema/beans/spring-beans-2.5.xsd http://www.springframework.org/schema/context http://www.springframework.org/schema/context/spring-context-2.5.xsd http://www.springframework.org/schema/aop http://www.springframework.org/schema/aop/spring-aop-2.5.xsd http://www.springframework.org/schema/tx http://www.springframework.org/schema/tx/spring-tx-2.5.xsd"> <bean id="dataSource" class="org.apache.commons.dbcp.BasicDataSource"> <property name="driverClassName" value="com.mysql.jdbc.Driver"></property> <property name="url" value="jdbc:mysql://localhost:3306/hk"></property> <property name="username" value="root"></property> <property name="password" value="123"></property> <property name="maxActive" value="100"></property> <property name="maxIdle" value="30"></property> <property name="maxWait" value="500"></property> <property name="defaultAutoCommit" value="true"></property> </bean> <bean id="sessionFactory" class="org.springframework.orm.hibernate3.LocalSessionFactoryBean"> <property name="dataSource"> <ref bean="dataSource" /> </property> <property name="hibernateProperties"> <props> <prop key="hibernate.dialect"> org.hibernate.dialect.MySQLDialect </prop> </props> </property> <property name="mappingResources"> <list> <value>vo/News.hbm.xml</value></list> </property></bean> <bean id="transactionManager" class="org.springframework.orm.hibernate3.HibernateTransactionManager"> <property name="sessionFactory" ref="sessionFactory" /> </bean> <tx:advice id="txAdvice" transaction-manager="transactionManager"> <tx:attributes> <tx:method name="save*" propagation="REQUIRED" /><!-- 只有一save、delete、update开头的方法才能执行增删改操作 --> <tx:method name="delete*" propagation="REQUIRED" /> <tx:method name="update*" propagation="REQUIRED" /> <tx:method name="*" propagation="SUPPORTS" read-only="true" /><!-- 其他方法为只读方法 --> </tx:attributes> </tx:advice> <aop:config> <aop:pointcut id="interceptorPointCuts" expression="execution(* news.serviceImpl..*.*(..))" /> <!-- 对应实现类接口的包的位置 --> <aop:advisor advice-ref="txAdvice" pointcut-ref="interceptorPointCuts" /> </aop:config> <!-- 业务层Service --> <bean id="news_service" class="service.impl.NewsServiceImpl"> <property name="sessionFactory"> <ref bean="sessionFactory"></ref> </property> </bean> <!-- 控制层Action --> <bean id="news_action" class="action.NewsAction"> <property name="news_services"> <ref bean="news_service" /> </property> </bean> </beans> 初学ssh的菜鸟,请各位大神帮忙解答一下!!谢谢!
谷歌和IE兼容问题,IE登录进入不了新页面
代码在谷歌可以登录成功,在IE浏览器,点击登录没反应,调试时进入登录方法执行成功,就是不跳转到新的页面,代码如下: (登录方法),求指点 function check(){ var a = $("#username").val(); var b = $("#password").val(); if(a==''){ // $.messager.alert('系统提示', '用户名不能为空', 'info'); $("#msg").html("用户名不能为空"); $("#username").focus(); return false; } else if(b==""){ $("#password").focus(); $("#msg").html("密码不能为空"); return false; } $.ajax({ url:'<%=path %>/sysLoginController/login.do', type:'post', data:{'username':a,'password':b}, success:function(data){ var json=eval('('+data+')'); console.info(json); if(json.status == '1'){ window.location.href="<%=path %>/index.jsp"; }else if(json.status == '3'){ $("#msg").html("用户名不存在,请重新输入"); return; }else if(json.status == '2'){ $("#msg").html("密码错误,请重新输入"); return; }else{ $("#msg").html("系统异常,请联系管理员!"); } } }); },
难了,有关ajax的执行问题
今天在jsp页面中这样执行了一个js,在这个js中把数据发送给servlet,可是遇到了一个很奇怪的问题: 在jsp页面中的代码是这样的: 1.<a href="javascript:void(0);" onclick="clearResum()">clearResum</a> 但是js中的clearResum()函数不执行,这个函数的主要功能是把数据发送到后台给servelt处理,也就是没有把数据发送给serlvet。 但是如果改成: 2.<a href=“#" onclick="clearResum()">clearResum</a>,则xmlHttpRequest.status的返回值始终是0,我已经把项目成功发布了,所以应该不存在tomcat的配置问题。 3.如果把 1 中的代码换成 <a href="javascript:clearResum()">clearResum</a>,这个js也始终不执行,而把clearResum()函数换成一个简单的test()函数( 这个函数只有一条alert("") )就可以执行。 4.在 1 中,如果把<a href=“#" onclick="clearResum()">clearResum</a>中的onclick="clearResum()"中的clearResum()函数换成一个简单的test()函数( 这个函数只有一条alert("") )就可以执行。 问题:被搞的很糊涂,非常不理解上述四点描述的问题,特别是第 1 点和第 3点,clearResum()为什么始终不执行,而第 4 点执行后得到的xmlHttpRequest.status的值始终是0?希望哪位兄弟帮忙解答一下,本人感激不尽,先谢谢了!! [b]问题补充:[/b] 谢谢 ham: clearResum() { send("clearResum?p=1"); } send()的方法体主要是建立xmlHttpRequest对象并发送数据和调用handleResponse方法处理服务器的返回信息。 还有,您能不能解释下<a href=" " onclick=" ">中href 和onclick执行js的区别,谢谢关注! [b]问题补充:[/b] 嗯,好,谢谢 ham 的解释,回头我再仔细检查和测试下function send()部分.
页面只发了一次请求,后台执行了两次代码,大概间隔了10s,求告知
$scope.submitFile = function (){ //判断参数 var fileName = document.getElementById("file").value; if(StringUtil.isBlank(fileName)){ toaster.pop("warning", "", "请选择文件"); return; } $scope.loading = true; $scope.loadText = "正在上传中..."; $.ajaxFileUpload({ url: './question/XXXX', //用于文件上传的服务器端请求地址 secureuri: false, //是否需要安全协议,一般设置为false fileElementId: 'file', //文件上传域的ID dataType: 'json', //返回值类型 一般设置为json success: function (data, status){ //服务器成功响应处理函数 $scope.loading = false; if(data.header.statusCode == 'success' && !$scope.loading) { if(StringUtil.isNotBlank(data.body) && StringUtil.isNotBlank(data.body.outPath)) { outPath = data.body.outPath; toaster.pop(data.header.statusCode.toLowerCase(), "", "文件上传成功,请选择题目分类"); return; } }else{ toaster.pop(data.header.statusCode.toLowerCase(), "", data.header.msgArray[0].desc); return; } }, error: function (data, status, e){//服务器响应失败处理函数 $scope.loading = false; toaster.pop(CommonUtil.TOASTER_WARNING, "", e); return; } }); } $scope.submitCode = function(){ if(StringUtil.isNotBlank(outPath)){ if(StringUtil.isBlank($scope.question_title)){ toaster.pop("warning", "", "请选择题目分类"); return; } if(StringUtil.isBlank($scope.question_category)){ toaster.pop("warning", "", "请选择题目类型"); return; } if($scope.question_category == "课文跟读"){//课文跟读 $scope.path = "./question/XXXX"; }else if($scope.question_category == "单词拼写"){//单词拼写 $scope.path = "./question/XXXX"; }else if($scope.question_category == "听音选词"){//听音选词 $scope.path = "./question/XXXX"; }else if($scope.question_category == "趣配音"){//趣配音 $scope.path = "./question/XXXX"; } $scope.loading = true; $scope.loadText = "正在上录入数据..."; $http.get($scope.path+"/?outPath="+outPath+"&title="+$scope.question_title).success(function(response) { //查找当前ID的分类信息 $scope.loading = false; if(!$scope.loading){ if(StringUtil.isNotBlank(response.body) && StringUtil.isNotBlank(response.body.createdNum)) { $scope.createdNum = response.body.createdNum; }else { $scope.createdNum = 0; } toaster.pop(response.header.statusCode.toLowerCase(), "", "成功录入或更新 "+$scope.createdNum+" 行数据"); $modalInstance.close(); //关闭模态框 refresh(); } }).error(function(response) { $scope.loading = false; toaster.pop(response.header.statusCode.toLowerCase(), "", response.header.msgArray[0].desc); }); }else{ toaster.pop("warning", "", "请先上传文件"); return; } } $scope.cancelCodeCreate = function() { //取消 $modalInstance.dismiss('cancel'); } } }); }
ajax无法发送请求,后台也未接收到请求
试了很多次,表单提交后,到alert(data)一句(包括这一句)都执行正常,但之后的ajax语句就无法发送请求,ajax语句里面的几个alert也没有运行,最后的alert('1')也没有运行(异步请求正常运行的话应该是会执行的吧) 以下是前端代码,本来代码是要复杂些的,但我调试的时候把代码简化了,基本确定是ajax语句的问题了。 ``` $(function () { 'use strict'; $('#login_form').submit(function (event) { event.stopPropagation(); event.preventDefault(); var nickname = $('#login_form').find('#login_nickname').val(); var pwd = $('#login_form').find('#login_password').val(); if (!nickname || !pwd) { $('#login_text').show(); } var raw_data = { title: 'login', nickname: nickname, password: pwd } var data = JSON.stringify(raw_data); alert(data); $.ajax('/login', { dataType: 'json' }).done(function (data) { alert('成功'); }).fail(function (xhr, status) { alert('失败'); }).always(function () { alert('请求完成: 无论成功或失败都会调用'); }); alert('1'); }); }); ``` 后端代码如下,用的是flask。按理来说即便url不对,后台也应该有请求记录的,然而后台并没有显示该记录 ``` @app.route('/login',methods=['POST',]) def login(): if g.user is not None and g.user.is_authenticated: flash('You have already logged in!') return redirect(url_for('home')) raw_data=request.get_data() print(raw_data) data=json.loads(raw_data) print(data[pwd],data[nickname]) resp=dict(success = True,text ='limbohotmore!') return json.dumps(resp) ``` 后台记录如下,无论提交几次表单,都只有第一次获取主页面的请求记录 ``` * Restarting with stat * Debugger is active! * Debugger PIN: 289-281-425 * Running on http://0.0.0.0:5000/ (Press CTRL+C to quit) 127.0.0.1 - - [26/Jul/2019 12:52:27] "GET / HTTP/1.1" 200 - ```
跪求高手指导hibernate此hql 怎么写
hql = "select distinct u from User " 跪求高手指导此hql 怎么写 用hql查询User 的时候, 只(ˇ?ˇ) 想~查出User 以及User .Station.id、User .Station.name、.User Station.dept,以及User Station.dept.id、User Station.dept.name 因为不这样的话 执行效率太低了。页面刷新很慢%>_<% [code=java] public class User implements Serializable{ private static final long serialVersionUID = 7259027197507200040L; private String id; private String username; private String password; private int status; private UserInfo userInfo; private Set<Station> stations; private Set<Role> roles; public String getId() { return id; } public void setId(String id) { this.id = id; } public String getUsername() { return username; } public void setUsername(String username) { this.username = username; } public String getPassword() { return password; } public void setPassword(String password) { this.password = password; } public UserInfo getUserInfo() { return userInfo; } public void setUserInfo(UserInfo userInfo) { this.userInfo = userInfo; } public Set<Station> getStations() { return stations; } public void setStations(Set<Station> stations) { this.stations = stations; } public Set<Role> getRoles() { return roles; } public void setRoles(Set<Role> roles) { this.roles = roles; } public int getStatus() { return status; } public void setStatus(int status) { this.status = status; } [/code] [code=java] public class Station implements Serializable{ private static final long serialVersionUID = 1L; private String id; private String name; private String descContent; private Date createTime; private int status; private Dept dept; private Set<User> users; private Set<DimTag> dimTags; public String getId() { return id; } public void setId(String id) { this.id = id; } public String getName() { return name; } public void setName(String name) { this.name = name; } public String getDescContent() { return descContent; } public void setDescContent(String descContent) { this.descContent = descContent; } public Date getCreateTime() { return createTime; } public void setCreateTime(Date createTime) { this.createTime = createTime; } public Dept getDept() { return dept; } public void setDept(Dept dept) { this.dept = dept; } public Set<User> getUsers() { return users; } public void setUsers(Set<User> users) { this.users = users; } public Set<DimTag> getDimTags() { return dimTags; } public void setDimTags(Set<DimTag> dimTags) { this.dimTags = dimTags; } public int getStatus() { return status; } public void setStatus(int status) { this.status = status; } } [/code] [code=java] public class Dept implements Serializable{ private static final long serialVersionUID = 1L; private String id; private String name; private Dept parent; private String bh; private String descContent; private int status; private Set<Station> station; public Set<Station> getStation() { return station; } public void setStation(Set<Station> station) { this.station = station; } public String getId() { return id; } public void setId(String id) { this.id = id; } public String getName() { return name; } public void setName(String name) { this.name = name; } public Dept getParent() { return parent; } public void setParent(Dept parent) { this.parent = parent; } public String getBh() { return bh; } public void setBh(String bh) { this.bh = bh; } public String getDescContent() { return descContent; } public void setDescContent(String descContent) { this.descContent = descContent; } public int getStatus() { return status; } public void setStatus(int status) { this.status = status; } } [/code] 跪求高手指导hibernate此hql 怎么写
springmvc +jquery ajax 404
springmvc +jquery ajax,后台没问题,能正常进去并执行完成,返回到页面之后, 一直进error,不进success js打印出来的东西: XMLHttpRequest.status:404 XMLHttpRequest.readyState:4 textStatus:error 真心不知道是什么问题,跟了一段时间,发现<mvc:annotation-driven/>是这个配置 引起了,去掉了就没问题,加上了就有问题了,这下更晕了 哪位大神来指点一二
终于明白阿里百度这样的大公司,为什么面试经常拿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#导入fbx c#中屏蔽键盘某个键 c#正态概率密度 c#和数据库登陆界面设计 c# 高斯消去法 c# codedom c#读取cad文件文本 c# 控制全局鼠标移动 c# temp 目录 bytes初始化 c#
立即提问