利用ajax方法 通过servlet文件 访问数据库 获取提示。汉字无法匹配?

html文件利用ajax方法 通过servlet文件 访问数据库 获取提示。汉字无法匹配?
Access数据库Goods表:
[img]http://dl.iteye.com/upload/attachment/0082/7368/85a5bb45-b636-3bbf-aa6e-1f1b7ef4a570.png[/img]

html文件suggest.html:


body { font: 11px arial; } .suggest_link { background-color: #FFFFFF; padding: 2px 6px 2px 6px; cursor:hand; } .suggest_link_over { background-color: #E8F2FE; padding: 2px 6px 2px 6px; } #search_suggest { position:relative; background-color: #FFFFFF; text-align: left; border: 1px solid #000000; left: -12px; top: 1px; height: 74px; width: 170px; display:none; }



实现搜索提示




ajax_search.js:
var searchReq = createAjaxObj();
function createAjaxObj()
{
var httprequest=false;
if (window.XMLHttpRequest) //为非IE浏览器生成XmlHttpRequest对象
{
httprequest=new XMLHttpRequest()
if (httprequest.overrideMimeType) httprequest.overrideMimeType('text/xml')
}
else if (window.ActiveXObject) //为IE浏览器生成XmlHttpRequest对象
{
try
{
httprequest=new ActiveXObject("Msxml2.XMLHTTP");
}
catch (e)
{
try
{
httprequest=new ActiveXObject("Microsoft.XMLHTTP");
}
catch (e){}
}
}
return httprequest
}
function searchSuggest()
{
if (searchReq.readyState == 4 || searchReq.readyState == 0)
{
var str = escape(document.getElementById('txtSearch').value);
searchReq.open("GET", 'search?search=' + str, true);//向服务器端发送请求
searchReq.onreadystatechange = handleSearchSuggest; //设置回调函数
searchReq.send(null);
}
}
function handleSearchSuggest()
{ //这是回调函数,处理从服务器端返回的信息
if (searchReq.readyState == 4)
{
var ss = document.getElementById('search_suggest')
ss.innerHTML = '';
var str = searchReq.responseText.split("\n");
for(i=0; i < str.length - 1; i++)
{
var suggest = '

suggest += 'onmouseout="javascript:suggestOut(this);" ';
suggest += 'onclick="javascript:setSearch(this.innerHTML);" ';
suggest += 'class="suggest_link">' + str[i] + '
';
ss.innerHTML += suggest;
ss.style.display="block";
}
}
}
function suggestOver(div_value)
{
div_value.className = 'suggest_link_over';
}
function suggestOut(div_value)
{
div_value.className = 'suggest_link';
}
function setSearch(value)
{
document.getElementById('txtSearch').value = value;
document.getElementById('search_suggest').innerHTML = '';
document.getElementById('search_suggest').style.display="none";
}

servlet文件SearchSuggest.java:
package com;
import java.sql.Connection;
import java.sql.DriverManager;
import java.sql.ResultSet;
import java.sql.SQLException;
import java.sql.Statement;
import java.util.ArrayList;

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

public class SearchSuggest extends HttpServlet
{
public void doPost(HttpServletRequest request, HttpServletResponse response) throws ServletException, java.io.IOException
{
response.setCharacterEncoding("UTF-8");
String search = request.getParameter("search"); //接受参数值

String sql = "select GoodsName from Goods where GoodsName like '"+search+"%' order by GoodsName";//设置查询语句
Connection conn = null;
Statement stmt = null;
ResultSet rs = null;
ArrayList vData = new ArrayList();
java.io.PrintWriter out = response.getWriter();
try {
Class.forName("sun.jdbc.odbc.JdbcOdbcDriver"); //注册数据库连接驱动

String MdbPath = "F:/sneaker/Tomcat/webapps/search/database/#costume.mdb";
String url= "jdbc:odbc:driver={Microsoft Access Driver (*.mdb)};DBQ=" + MdbPath ;
conn = DriverManager.getConnection(url);

stmt = conn.createStatement();
rs = stmt.executeQuery(sql); //执行查询
while (rs.next())
{
vData.add(rs.getString("GoodsName"));
}
StringBuilder buf = new StringBuilder();
for (int i=0;i<vData.size();i++)
{
String keyword = (String)vData.get(i);
buf.append(keyword+"\n");
}
out.print(buf.toString());//向客户端输出信息
} catch (Exception e) {
e.printStackTrace();
} finally {
try {
if (stmt != null)
stmt.close();
if (conn != null)
conn.close();
} catch (SQLException sqle) {
}
}
}
public void doGet(HttpServletRequest request, HttpServletResponse response)
throws ServletException, java.io.IOException
{
doPost(request, response);
}
}

效果当输入为空时,可以调出数据表中所有信息 汉字及数字正常显示:

[img]http://dl.iteye.com/upload/attachment/0082/7376/1de0c6c5-0934-3f36-888a-af0bae38f84a.png[/img]

当输入数字7时,可以匹配:

[img]http://dl.iteye.com/upload/attachment/0082/7378/967d1012-b3db-39e8-bd6f-7b0d5186e3c6.png[/img]

当输入汉字儿童 或 额 时,匹配信息没有显示,是因为所输入的汉字编码有误吗,没有传递或传递后编码不匹配吗?求解?

[img]http://dl.iteye.com/upload/attachment/0082/7382/413d2446-1db1-344f-b7ba-0f834a0b72b0.png[/img]

[img]http://dl.iteye.com/upload/attachment/0082/7393/4ebd495e-1501-3593-909a-3929ed218695.png[/img]

Tomcat提示:
[img]http://dl.iteye.com/upload/attachment/0082/7677/d874bf7e-8d11-3c25-866a-ad7f9c25ce19.gif[/img]

2个回答

在客户端,对即将通过Ajax传递到后台的字符串,进行两次编码。

修改前:
[code="javascript"]var str = escape(document.getElementById('txtSearch').value); [/code]

修改后:
[code="javascript"]var str = encodeURI(encodeURI(document.getElementById('txtSearch').value)); [/code]

遇到这种问题,应该首先在以下代码处打断点进行调试,看后台获得的字符串是否是乱码:
[code="java"]String search = request.getParameter("search"); //接受参数值[/code]

yunzhu666
yunzhu666 JavaScript encodeURI() 函数 [url]http://www.w3school.com.cn/js/jsref_encodeURI.asp/url] URL编码与二次encodeURI [url]http://foryougeljh.iteye.com/blog/1456706/url]
接近 7 年之前 回复
weixin_42502701
囍相逢²LIQP 关于encodeURI的使用,应该查哪里资料?谢谢。
接近 7 年之前 回复

客户端建议使用
encodeURIComponent 而不是escape
在服务器端
URLDecoder.decode(search, "UTF-8")
如果不行可使用apache common lang StringEscapeUtils 工具类

Csdn user default icon
上传中...
上传图片
插入图片
抄袭、复制答案,以达到刷声望分或其他目的的行为,在CSDN问答是严格禁止的,一经发现立刻封号。是时候展现真正的技术了!
其他相关推荐
html文件利用ajax方法 通过 servlet 获取数据库信息 显示乱码,求解?
html文件利用ajax方法 通过 servlet 获取数据库信息 显示乱码,求解? suggest.html: <html> <head> <meta http-equiv="content-type" content="text/html; charset=UTF-8"> <script language="JavaScript" type="text/javascript" src="ajax_search.js"></script> <style type="text/css" media="screen"> body { font: 11px arial; } .suggest_link { background-color: #FFFFFF; padding: 2px 6px 2px 6px; cursor:hand; } .suggest_link_over { background-color: #E8F2FE; padding: 2px 6px 2px 6px; } #search_suggest { position:relative; background-color: #FFFFFF; text-align: left; border: 1px solid #000000; left: -12px; top: 1px; height: 74px; width: 170px; display:none; } </style> </head> <body background="bg.gif"> <center> <h3>实现搜索提示</h3> <div style="width: 500px;"> <input type="text" id="txtSearch" name="txtSearch" onKeyUp="searchSuggest();" autocomplete="off" /> <input type="submit" id="cmdSearch" name="cmdSearch" value="搜索"/><br /> <div id="search_suggest"></div> </div> </center> </body> </html> ajax_search.js: var searchReq = createAjaxObj(); function createAjaxObj() { var httprequest=false; if (window.XMLHttpRequest) //为非IE浏览器生成XmlHttpRequest对象 { httprequest=new XMLHttpRequest() if (httprequest.overrideMimeType) httprequest.overrideMimeType('text/xml') } else if (window.ActiveXObject) //为IE浏览器生成XmlHttpRequest对象 { try { httprequest=new ActiveXObject("Msxml2.XMLHTTP"); } catch (e) { try { httprequest=new ActiveXObject("Microsoft.XMLHTTP"); } catch (e){} } } return httprequest } function searchSuggest() { if (searchReq.readyState == 4 || searchReq.readyState == 0) { var str = document.getElementById('txtSearch').value; [b]searchReq.open("GET", 'search?search=' + str, true);//向服务器端发送请求[/b] searchReq.onreadystatechange = handleSearchSuggest; //设置回调函数 searchReq.send(null); } } function handleSearchSuggest() { //这是回调函数,处理从服务器端返回的信息 if (searchReq.readyState == 4) { var ss = document.getElementById('search_suggest') ss.innerHTML = ''; var str = searchReq.responseText.split("\n"); for(i=0; i < str.length - 1; i++) { var suggest = '<div onmouseover="javascript:suggestOver(this);" '; suggest += 'onmouseout="javascript:suggestOut(this);" '; suggest += 'onclick="javascript:setSearch(this.innerHTML);" '; suggest += 'class="suggest_link">' + str[i] + '</div>'; ss.innerHTML += suggest; ss.style.display="block"; } } } function suggestOver(div_value) { div_value.className = 'suggest_link_over'; } function suggestOut(div_value) { div_value.className = 'suggest_link'; } function setSearch(value) { document.getElementById('txtSearch').value = value; document.getElementById('search_suggest').innerHTML = ''; document.getElementById('search_suggest').style.display="none"; } Servlet文件SearchSuggest.java: package com; import java.sql.Connection; import java.sql.DriverManager; import java.sql.ResultSet; import java.sql.SQLException; import java.sql.Statement; import java.util.ArrayList; import javax.servlet.ServletException; import javax.servlet.http.HttpServlet; import javax.servlet.http.HttpServletRequest; import javax.servlet.http.HttpServletResponse; public class SearchSuggest extends HttpServlet { public void doPost(HttpServletRequest request, HttpServletResponse response) throws ServletException, java.io.IOException { String search = request.getParameter("search"); //接受参数值 String sql = "select GoodsName from Goods where GoodsName like '"+search+"%' order by GoodsName";//设置查询语句 Connection conn = null; Statement stmt = null; ResultSet rs = null; ArrayList vData = new ArrayList(); java.io.PrintWriter out = response.getWriter(); try { Class.forName("sun.jdbc.odbc.JdbcOdbcDriver"); //注册数据库连接驱动 String MdbPath = "F:/shop.mdb"; String url= "jdbc:odbc:driver={Microsoft Access Driver (*.mdb)};DBQ=" + MdbPath ; conn = DriverManager.getConnection(url); stmt = conn.createStatement(); rs = stmt.executeQuery(sql); //执行查询 while (rs.next()) { vData.add(rs.getString("GoodsName")); } StringBuilder buf = new StringBuilder(); for (int i=0;i<vData.size();i++) { String keyword = (String)vData.get(i); buf.append(keyword+"\n"); } out.print(buf.toString());//向客户端输出信息 } catch (Exception e) { e.printStackTrace(); } finally { try { if (stmt != null) stmt.close(); if (conn != null) conn.close(); } catch (SQLException sqle) { } } } public void doGet(HttpServletRequest request, HttpServletResponse response) throws ServletException, java.io.IOException { doPost(request, response); } } 效果图: [img]http://dl.iteye.com/upload/attachment/0082/7129/bd3b22cd-f7f5-3ec1-8a06-3daca35838e1.png[/img]
ajax如何获取servlet的数据
servlet已经取出了数据,显示在html上 servlet: public void doGet(HttpServletRequest req, HttpServletResponse resp) throws ServletException, IOException { Connection conn = DBConnectUtils.getConnection(); PreparedStatement pstmt = null; ResultSet rs = null; try { String sql = "select id,username from User"; pstmt = conn.prepareStatement(sql); rs = pstmt.executeQuery(); if (rs != null) { while (rs.next()) { req.setAttribute("id", rs.getInt("id")); req.setAttribute("username", rs.getString("username")); req.getRequestDispatcher("showUser.html").forward(req, resp); } } } catch (Exception e) { e.printStackTrace(); } finally { DBCloseUtils.closeCSR(conn, pstmt, rs); } } ajax应该怎么写
ajax通过java Servlet返回的数据问题
就是 ajax 提交服务器的请求 然后 服务器返回的数据 用 json 嘛 就是 通过JSONArray 把List或者javabean转成 json格式,在 通过 PrintWrite输出嘛, 如果我要输出的是两个不同的对象,一个是List集合转换过来的,另外一个还要输出一个javabean,用于分页的,但是这些输出后最后在ajax那里 var data = xmlRequest.responseText 它就全部组合成一个字符串了,怎么给它分开呢。我是在做一个书籍的留言评论,然后 我的要求是 留言翻页的时候我通过ajax来提交的,去数据库查到数据List集合后通过JSONArray专JSON格式,但是我还在界面显示还需要一个分页的 javabean需要传到页面上去,请问我用ajax这个时候该怎么提取数据?还在在servlet上该如何发送数据。因为一个是 发送list转成的json 另外一个是 分页javabean转成的json.............求各位大神讲解
怎么用servlet获取oracle数据库信息后传递到jquery的ajax上进行验证
``` package com.ibm.ajax.app1.entity; public class WebUser { private String uname; public WebUser(String uname){ this.uname=uname; } public String getUname() { return uname; } public void setUname(String uname) { this.uname = uname; } } ``` ``` package com.ibm.ajax.app1.dao; import java.sql.Connection; import java.sql.DriverManager; import java.sql.ResultSet; import java.sql.Statement; import java.util.List; import java.util.Vector; import com.ibm.ajax.app1.entity.WebUser; public class WebUserDao { public List<WebUser> queryList() throws Exception{ String username="gdx"; String password="wazzh"; String url="jdbc:oracle:thin:@//localhost:1521/orcl"; String driver="oracle.jdbc.driver.OracleDriver"; List<WebUser> lists=new Vector<WebUser>(); Class.forName(driver); Connection conn=DriverManager.getConnection(url, username, password); Statement stmt =conn.createStatement(); ResultSet rs=stmt.executeQuery("select UNAME from webUser"); while(rs.next()){ WebUser webuser=new WebUser(rs.getString("UNAME")); lists.add(webuser); } return lists; } } ``` ``` package com.ibm.ajax.app1.service.impl; import java.util.List; import com.ibm.ajax.app1.dao.WebUserDao; import com.ibm.ajax.app1.entity.WebUser; import com.ibm.ajax.app1.service.IWebUserService; public class WebUserServiceImpl implements IWebUserService { private WebUserDao webuserdao= new WebUserDao(); @Override public List<WebUser> getWebUserList() throws Exception { List<WebUser> lists= webuserdao.queryList(); return lists; } } ``` ``` package com.ibm.ajax.app1.service; import java.util.List; import com.ibm.ajax.app1.entity.WebUser; public interface IWebUserService { //获取我建立的实体对象WebUser的list表 public List<WebUser> getWebUserList() throws Exception; } ``` ``` package com.ibm.ajax.app1.servlet; import java.io.IOException; import java.util.List; import javax.servlet.ServletException; import javax.servlet.http.HttpServlet; import javax.servlet.http.HttpServletRequest; import javax.servlet.http.HttpServletResponse; import com.ibm.ajax.app1.entity.WebUser; import com.ibm.ajax.app1.service.IWebUserService; import com.ibm.ajax.app1.service.impl.WebUserServiceImpl; /** * Servlet implementation class ValiateUserNameServlet */ public class ValiateUserNameServlet extends HttpServlet { private static final long serialVersionUID = 1L; private IWebUserService webuserservice; @Override protected void doPost(HttpServletRequest request, HttpServletResponse response) throws ServletException, IOException { webuserservice = new WebUserServiceImpl(); try{ List<WebUser> userNames=webuserservice.getWebUserList(); System.out.println(userNames); //这之上的是写的从数据库调取的语句 String userName=request.getParameter("userName"); String result=null; if(userNames.contains(userName) ){ result="<font color='red'>该用户已存在</font>"; } else{ result="<font color='green'>该用户不存在</font>"; } System.out.println("sdf"); response.setContentType("text/html ; charset=UTF-8"); response.setCharacterEncoding("UTF-8"); response.getWriter().print(result); } catch(Exception ex){ System.out.println(ex); } } } ``` ``` <%@ 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>Insert title here</title> <script type="text/javascript" src="${pageContext.request.contextPath }/scripts/jquery-1.7.2.js "></script> <script type="text/javascript"> $(function(){ $(":input[name='username']").change(function(){ var val=$(this).val(); val=$.trim(val); if(val!=" "){ var url="${pageContext.request.contextPath }/valiateUserName"; var args={"userName":val,"time":new Date()}; $.post(url,args,function(data){ $("#message").html(data); }); } }); }) </script> </head> <body> <form action="" method="post"> UserName:<input type="text" name="username" /> <div id="message"></div> <input type="submit" value="Submit" /> </form> </body> </html> ```
vue下拉框怎样从数据库获取数据?
vue从数据库获取数据显示到页面下拉框里面;目前有后端的查询所有数据的端口,求源码。![图片说明](https://img-ask.csdn.net/upload/201912/11/1576032653_665124.png)
Servlet如何获取ajax中以json格式传入的数据?
已经纠结了一天,帮帮忙,越详细越好,已经实现从servlet中获取json格式的数据,那么,在servlet如何获取ajax中以json格式传入的数据
juqery ajax 获取oracle数据库问题
如何使用jquery ajax()获取oracle数据库表中的信息
不会利用Ajax访问链接,请各位帮看下
利用ajax技术访问链接:http://clovert.top/mosAdvance,传递参数name,传值方式为post。。。我看了一下不是很清楚。。查了下教程,看到的都是通过ajax请求后返回一个字符串啥的然后添加到网页里,但这个用ajax访问就不是很清楚了。 拜托了
webdriver如何获取ajax加载出来的数据?
使用chrome webdriver 访问网页后,ajax能自动访问到数据,但是页面只会显示其中一部分,我想获取ajax返回的全部内容? 请问哪位大大能帮忙解决下???? Thanks♪(・ω・)ノ
关于ajax连接servlet的问题
最近开始学习ajax,看的是《ajax基础教程》一书。 书中一个测试代码,在html页面中使用ajax连接servlet发送参数,返回一些数据。 但是始终出错,显示404,找不到servlet文件。 我是在myEclipse中部署的,书中在NetBeans中部署,所以下载的代码不能直接使用。 我复制了html文件,重新生成了servlet,复制代码进去。 不知道操作上有没有什么错误?
ajax获取Servlet中的JSON的问题。
在js中请求ajax,把jsp中的一个Cno传到Servlet中 ``` $.ajax({ type :"post", url : "ShowDetail?Cno="+Cno, async:false, dataType : "json", success : function(data) { }, error : function() { var student =eval("(" +result +")"); alert(student.Cth1); } }); ``` 在Servlet中获取后台值,并out.print JSON格式 ``` out.print("[{'Cno':'"+Cno+"','Cth1':'"+cd.get(0).getCth1()+"']}); ``` 应该如何通过ajax获取这里面的值 我通过 var student =eval("(" +result +")"); 的方法,但是student.Cth1获取不了值 这里用Error是因为Success没有反应。
自动补全(bootstrap-typeahead)利用ajax获取数据,求教
自动补全(bootstrap-typeahead)利用ajax获取数据,求教
用jquery ajax从数据库获取数据实现二级联动
我的思路就是一级那里搞个select,然后利用ajax返回action。然后利用ajax那里不懂。哪位大神教我怎么做? 1、这是select, function select(){ var xitong=document.getElementById("xitong").value; $.ajax({ url:'/netbank/budiao/testaj', type:'post', dataType:'json', data:{"xitong.xitongname":xitong}, error: function(){ alert("服务器没有返回数据,可能服务器忙,请重试"); }, success:createshebeiname2 }); 2、这是/netbank/budiao/testaj', public String testaj(){ System.out.println("testaj"); String name=xitong.getXitongname(); System.out.println(name); shebeilist=budiaoBiz.getShebeibyname(xitong.getXitongname()); request.put("shebeilist", shebeilist); return "testaj"; } 3、这是struts.xml的一部分 <package name="budiao" namespace="/budiao" extends="json-default" > <action name="*" class="budiao" method="{1}"> <result name="testaj" type="json"></result> 结果:select选择的时候,能够打印出testaj和xitongname的值,还有alert("服务器没有返回数据,可能服务器忙,请重试");
微服务如何解决跨域问题。跪求大佬!!
本机端口号8010工程中的前端页面,超链接需要访问到8011工程中的controller方法,方法用于执行业务并跳转到8011的页面,,这个咋整?? jsonp跨域方式好像需要ajax方式提交,但这样就无法跳转页面了。。 求各路大神解答!!万分感谢!!!
在servlet接ajax传入的值,无法接收到
![图片说明](https://img-ask.csdn.net/upload/201912/28/1577542172_392870.png) ![图片说明](https://img-ask.csdn.net/upload/201912/28/1577542237_214581.png) 框中的可以在servlet中通过request.getParameter("name")获取到值,但是换成Stringify就不可以,而且json字符串变成请求的key值。 ![图片说明](https://img-ask.csdn.net/upload/201912/28/1577542289_59746.png) 测试结果如下,请各位大神指教
servlet查出数据库图片让页面显示的问题
各位CSDN的朋友,大家好。今天做一个用户头像的上传显示遇到了一个问题,在此想请教一下大家。 首先,servlet的到数据库的图片后,通过以下代码发到jsp中: ![图片说明](https://img-ask.csdn.net/upload/201710/21/1508553311_881890.jpg) 然后。jsp页面使用<img alt='头像' width='158px' height='188px' src='${pageContext.request.contextPath }/JsTxShowServlet?gonghao=102'> 来接收信息并显示图片。当然,图片也能正常显示,但如果jsp页面采用ajax向该servlet发请求,并将获得的响应信息直接赋值给src属性,显示的确实一窜乱码,即<img alt='头像' width='158px' height='188px' src=‘data’>,data为ajax的响应响应数据。 希望大家能讨论一下,共获提升,不胜感激!
js中使用ajax函数做同步请求Servlet连接数据库进行验证
这是一个js表单验证,验证email的部分,我想达到的目的是在输入email信息结束后进行验证,前两个条件直接自身进行验证,效果已经实现了,后面的那个我想用ajax的效果进行同步验证,防止email重复,但是效果一直出不来,不知道是否是ajax函数参数设置有问题什么的,或者eclipse出bug什么的,请问有人帮忙看一下的么? email输入部分代码: <tr> <td class="tdLabel">Email:</td> <td class="tdInput"><input type="text" name="email" id="email" class="input" value="" /></td> <td class="tdError"><label class="labelError" id="emailError"></label> </td> </tr> js代码如下: function validateEmail() { $("#emailError").css("display", "none"); var bool = true; var val = $("#email").val(); if(!val) { $("#emailError").text("Email不能为空!"); $("#emailError").css("display", ""); bool = false; } else if(!/^([a-zA-Z0-9_-])+@([a-zA-Z0-9_-])+((\.[a-zA-Z0-9_-]{2,3}){1,2})$/.test(val)) { $("#emailError").text("错误的Email格式!"); $("#emailError").css("display", ""); bool = false; } else { $.ajax({ url:"/goods/UserServlet", data:{method:"ajaxValidateEmail",email:value}, type:"POST", dataType:"json", async:false, cache:false, success:function(result){ if(!result){ $("#emailError").text("该邮箱已经被注册了"); $("#emailError").css("display", ""); bool = false; } } }); } return bool; } 请求的Servlet的函数如下: public void ajaxValidateEmail(HttpServletRequest request, HttpServletResponse response) throws ServletException, IOException { String email = request.getParameter("email"); boolean emailPass = userService.ajaxValidateEmail(email); response.getWriter().print(emailPass); } service部分: public boolean ajaxValidateEmail(String email){ return userDao.ajaxValidateLoginname(email); } 数据库层代码: public boolean ajaxValidateEmail(String email){ String sql = "select count(1) from t_user where email=?"; try { Number number = (Number)queryRunner.query(sql, new ScalarHandler(), email); return number.intValue() == 0; } catch (SQLException e) { throw new RuntimeException(e); } }
ajax json 咋显示数据库 数据
我要做个进入网站首页就用ajax json获取数据库数据,显示在页面上 前后台怎么写啊? 具体一点的 最好有代码例子= =
怎么用ajax把数据库的数据显示在基于vue前端页面上?
毕业设计软硬件结合时,怎么把传感器采集的数据显示到前端页面(用vue jquery等写的页面)然后存储到数据库,再进行历史查询
Java学习的正确打开方式
在博主认为,对于入门级学习java的最佳学习方法莫过于视频+博客+书籍+总结,前三者博主将淋漓尽致地挥毫于这篇博客文章中,至于总结在于个人,实际上越到后面你会发现学习的最好方式就是阅读参考官方文档其次就是国内的书籍,博客次之,这又是一个层次了,这里暂时不提后面再谈。博主将为各位入门java保驾护航,各位只管冲鸭!!!上天是公平的,只要不辜负时间,时间自然不会辜负你。 何谓学习?博主所理解的学习,它是一个过程,是一个不断累积、不断沉淀、不断总结、善于传达自己的个人见解以及乐于分享的过程。
程序员必须掌握的核心算法有哪些?
由于我之前一直强调数据结构以及算法学习的重要性,所以就有一些读者经常问我,数据结构与算法应该要学习到哪个程度呢?,说实话,这个问题我不知道要怎么回答你,主要取决于你想学习到哪些程度,不过针对这个问题,我稍微总结一下我学过的算法知识点,以及我觉得值得学习的算法。这些算法与数据结构的学习大多数是零散的,并没有一本把他们全部覆盖的书籍。下面是我觉得值得学习的一些算法以及数据结构,当然,我也会整理一些看过...
大学四年自学走来,这些私藏的实用工具/学习网站我贡献出来了
大学四年,看课本是不可能一直看课本的了,对于学习,特别是自学,善于搜索网上的一些资源来辅助,还是非常有必要的,下面我就把这几年私藏的各种资源,网站贡献出来给你们。主要有:电子书搜索、实用工具、在线视频学习网站、非视频学习网站、软件下载、面试/求职必备网站。 注意:文中提到的所有资源,文末我都给你整理好了,你们只管拿去,如果觉得不错,转发、分享就是最大的支持了。 一、电子书搜索 对于大部分程序员...
linux系列之常用运维命令整理笔录
本博客记录工作中需要的linux运维命令,大学时候开始接触linux,会一些基本操作,可是都没有整理起来,加上是做开发,不做运维,有些命令忘记了,所以现在整理成博客,当然vi,文件操作等就不介绍了,慢慢积累一些其它拓展的命令,博客不定时更新 free -m 其中:m表示兆,也可以用g,注意都要小写 Men:表示物理内存统计 total:表示物理内存总数(total=used+free) use...
比特币原理详解
一、什么是比特币 比特币是一种电子货币,是一种基于密码学的货币,在2008年11月1日由中本聪发表比特币白皮书,文中提出了一种去中心化的电子记账系统,我们平时的电子现金是银行来记账,因为银行的背后是国家信用。去中心化电子记账系统是参与者共同记账。比特币可以防止主权危机、信用风险。其好处不多做赘述,这一层面介绍的文章很多,本文主要从更深层的技术原理角度进行介绍。 二、问题引入 假设现有4个人...
程序员接私活怎样防止做完了不给钱?
首先跟大家说明一点,我们做 IT 类的外包开发,是非标品开发,所以很有可能在开发过程中会有这样那样的需求修改,而这种需求修改很容易造成扯皮,进而影响到费用支付,甚至出现做完了项目收不到钱的情况。 那么,怎么保证自己的薪酬安全呢? 我们在开工前,一定要做好一些证据方面的准备(也就是“讨薪”的理论依据),这其中最重要的就是需求文档和验收标准。一定要让需求方提供这两个文档资料作为开发的基础。之后开发...
网页实现一个简单的音乐播放器(大佬别看。(⊙﹏⊙))
今天闲着无事,就想写点东西。然后听了下歌,就打算写个播放器。 于是乎用h5 audio的加上js简单的播放器完工了。 演示地点演示 html代码如下` music 这个年纪 七月的风 音乐 ` 然后就是css`*{ margin: 0; padding: 0; text-decoration: none; list-...
Python十大装B语法
Python 是一种代表简单思想的语言,其语法相对简单,很容易上手。不过,如果就此小视 Python 语法的精妙和深邃,那就大错特错了。本文精心筛选了最能展现 Python 语法之精妙的十个知识点,并附上详细的实例代码。如能在实战中融会贯通、灵活使用,必将使代码更为精炼、高效,同时也会极大提升代码B格,使之看上去更老练,读起来更优雅。
数据库优化 - SQL优化
以实际SQL入手,带你一步一步走上SQL优化之路!
通俗易懂地给女朋友讲:线程池的内部原理
餐盘在灯光的照耀下格外晶莹洁白,女朋友拿起红酒杯轻轻地抿了一小口,对我说:“经常听你说线程池,到底线程池到底是个什么原理?”
经典算法(5)杨辉三角
杨辉三角 是经典算法,这篇博客对它的算法思想进行了讲解,并有完整的代码实现。
使用 Docker 部署 Spring Boot 项目
Docker 技术发展为微服务落地提供了更加便利的环境,使用 Docker 部署 Spring Boot 其实非常简单,这篇文章我们就来简单学习下。首先构建一个简单的 S...
英特尔不为人知的 B 面
从 PC 时代至今,众人只知在 CPU、GPU、XPU、制程、工艺等战场中,英特尔在与同行硬件芯片制造商们的竞争中杀出重围,且在不断的成长进化中,成为全球知名的半导体公司。殊不知,在「刚硬」的背后,英特尔「柔性」的软件早已经做到了全方位的支持与支撑,并持续发挥独特的生态价值,推动产业合作共赢。 而对于这一不知人知的 B 面,很多人将其称之为英特尔隐形的翅膀,虽低调,但是影响力却不容小觑。 那么,在...
面试官:你连RESTful都不知道我怎么敢要你?
干货,2019 RESTful最贱实践
刷了几千道算法题,这些我私藏的刷题网站都在这里了!
遥想当年,机缘巧合入了 ACM 的坑,周边巨擘林立,从此过上了"天天被虐似死狗"的生活… 然而我是谁,我可是死狗中的战斗鸡,智力不够那刷题来凑,开始了夜以继日哼哧哼哧刷题的日子,从此"读题与提交齐飞, AC 与 WA 一色 ",我惊喜的发现被题虐既刺激又有快感,那一刻我泪流满面。这么好的事儿作为一个正直的人绝不能自己独享,经过激烈的颅内斗争,我决定把我私藏的十几个 T 的,阿不,十几个刷题网...
白话阿里巴巴Java开发手册高级篇
不久前,阿里巴巴发布了《阿里巴巴Java开发手册》,总结了阿里巴巴内部实际项目开发过程中开发人员应该遵守的研发流程规范,这些流程规范在一定程度上能够保证最终的项目交付质量,通过在时间中总结模式,并推广给广大开发人员,来避免研发人员在实践中容易犯的错误,确保最终在大规模协作的项目中达成既定目标。 无独有偶,笔者去年在公司里负责升级和制定研发流程、设计模板、设计标准、代码标准等规范,并在实际工作中进行...
SQL-小白最佳入门sql查询一
不要偷偷的查询我的个人资料,即使你再喜欢我,也不要这样,真的不好;
redis分布式锁,面试官请随便问,我都会
文章有点长并且绕,先来个图片缓冲下! 前言 现在的业务场景越来越复杂,使用的架构也就越来越复杂,分布式、高并发已经是业务要求的常态。像腾讯系的不少服务,还有CDN优化、异地多备份等处理。 说到分布式,就必然涉及到分布式锁的概念,如何保证不同机器不同线程的分布式锁同步呢? 实现要点 互斥性,同一时刻,智能有一个客户端持有锁。 防止死锁发生,如果持有锁的客户端崩溃没有主动释放锁,也要保证锁可以正常释...
项目中的if else太多了,该怎么重构?
介绍 最近跟着公司的大佬开发了一款IM系统,类似QQ和微信哈,就是聊天软件。我们有一部分业务逻辑是这样的 if (msgType = "文本") { // dosomething } else if(msgType = "图片") { // doshomething } else if(msgType = "视频") { // doshomething } else { // doshom...
Nginx 原理和架构
Nginx 是一个免费的,开源的,高性能的 HTTP 服务器和反向代理,以及 IMAP / POP3 代理服务器。Nginx 以其高性能,稳定性,丰富的功能,简单的配置和低资源消耗而闻名。 Nginx 的整体架构 Nginx 里有一个 master 进程和多个 worker 进程。master 进程并不处理网络请求,主要负责调度工作进程:加载配置、启动工作进程及非停升级。worker 进程负责处...
“狗屁不通文章生成器”登顶GitHub热榜,分分钟写出万字形式主义大作
一、垃圾文字生成器介绍 最近在浏览GitHub的时候,发现了这样一个骨骼清奇的雷人项目,而且热度还特别高。 项目中文名:狗屁不通文章生成器 项目英文名:BullshitGenerator 根据作者的介绍,他是偶尔需要一些中文文字用于GUI开发时测试文本渲染,因此开发了这个废话生成器。但由于生成的废话实在是太过富于哲理,所以最近已经被小伙伴们给玩坏了。 他的文风可能是这样的: 你发现,...
程序员:我终于知道post和get的区别
是一个老生常谈的话题,然而随着不断的学习,对于以前的认识有很多误区,所以还是需要不断地总结的,学而时习之,不亦说乎
《程序人生》系列-这个程序员只用了20行代码就拿了冠军
你知道的越多,你不知道的越多 点赞再看,养成习惯GitHub上已经开源https://github.com/JavaFamily,有一线大厂面试点脑图,欢迎Star和完善 前言 这一期不算《吊打面试官》系列的,所有没前言我直接开始。 絮叨 本来应该是没有这期的,看过我上期的小伙伴应该是知道的嘛,双十一比较忙嘛,要值班又要去帮忙拍摄年会的视频素材,还得搞个程序员一天的Vlog,还要写BU...
加快推动区块链技术和产业创新发展,2019可信区块链峰会在京召开
11月8日,由中国信息通信研究院、中国通信标准化协会、中国互联网协会、可信区块链推进计划联合主办,科技行者协办的2019可信区块链峰会将在北京悠唐皇冠假日酒店开幕。   区块链技术被认为是继蒸汽机、电力、互联网之后,下一代颠覆性的核心技术。如果说蒸汽机释放了人类的生产力,电力解决了人类基本的生活需求,互联网彻底改变了信息传递的方式,区块链作为构造信任的技术有重要的价值。   1...
Java世界最常用的工具类库
Apache Commons Apache Commons有很多子项目 Google Guava 参考博客
程序员把地府后台管理系统做出来了,还有3.0版本!12月7号最新消息:已在开发中有github地址
第一幕:缘起 听说阎王爷要做个生死簿后台管理系统,我们派去了一个程序员…… 996程序员做的梦: 第一场:团队招募 为了应对地府管理危机,阎王打算找“人”开发一套地府后台管理系统,于是就在地府总经办群中发了项目需求。 话说还是中国电信的信号好,地府都是满格,哈哈!!! 经常会有外行朋友问:看某网站做的不错,功能也简单,你帮忙做一下? 而这次,面对这样的需求,这个程序员...
网易云6亿用户音乐推荐算法
网易云音乐是音乐爱好者的集聚地,云音乐推荐系统致力于通过 AI 算法的落地,实现用户千人千面的个性化推荐,为用户带来不一样的听歌体验。 本次分享重点介绍 AI 算法在音乐推荐中的应用实践,以及在算法落地过程中遇到的挑战和解决方案。 将从如下两个部分展开: AI算法在音乐推荐中的应用 音乐场景下的 AI 思考 从 2013 年 4 月正式上线至今,网易云音乐平台持续提供着:乐屏社区、UGC...
【技巧总结】位运算装逼指南
位算法的效率有多快我就不说,不信你可以去用 10 亿个数据模拟一下,今天给大家讲一讲位运算的一些经典例子。不过,最重要的不是看懂了这些例子就好,而是要在以后多去运用位运算这些技巧,当然,采用位运算,也是可以装逼的,不信,你往下看。我会从最简单的讲起,一道比一道难度递增,不过居然是讲技巧,那么也不会太难,相信你分分钟看懂。 判断奇偶数 判断一个数是基于还是偶数,相信很多人都做过,一般的做法的代码如下...
为什么要学数据结构?
一、前言 在可视化化程序设计的今天,借助于集成开发环境可以很快地生成程序,程序设计不再是计算机专业人员的专利。很多人认为,只要掌握几种开发工具就可以成为编程高手,其实,这是一种误解。要想成为一个专业的开发人员,至少需要以下三个条件: 1) 能够熟练地选择和设计各种数据结构和算法 2) 至少要能够熟练地掌握一门程序设计语言 3) 熟知所涉及的相关应用领域的知识 其中,后两个条件比较容易实现,而第一个...
Android 9.0 init 启动流程
阅读五分钟,每日十点,和您一起终身学习,这里是程序员Android本篇文章主要介绍Android开发中的部分知识点,通过阅读本篇文章,您将收获以下内容:一、启动流程概述一、 启动流程概述Android启动流程跟Linux启动类似,大致分为如下五个阶段。1.开机上电,加载固化的ROM。2.加载BootLoader,拉起Android OS。3.加载Uboot,初始外设,引导Kernel启动等。...
相关热词 基于c#波形控件 c# 十进制转十六进制 对文件aes加密vc# c#读取栈中所有的值 c# rsa256加密 好 学c# 还是c++ c# 和java的差距 c# curl网络框架 c# https证书请求 c# 中崎
立即提问