최근 jsp 학생 정보 관리 시스템을 개발 중인데, 이제 막 jsp를 접하게 되어서 많은 문제에 봉착하게 되었는데, 녹화해서 공유해보겠습니다.
서블릿 예제에 대한 Jquery ajax 제출 양식
프론트 엔드 부분 코드:
<form class="addSud" method="post" action=""> <table> <tr> <td class="textRight">姓名</td> <td colspan="2"><input type="text" id="name" name="name"></td> <td class="textRight">学号</td> <td colspan="2"><input type="text" id="studentId" name="studentId"></td> </tr> <tr> <td colspan="5"> <input type="submit" id="addStudents" value="提交"></td> </tr> </table> </form>
ajax 제출 양식 코드:
//增加学生,异步提交学生表单 $("#addStudents").click(function() { $.ajax({ url: "addStudents.do",//要请求的服务器url //这是一个对象,表示请求的参数,两个参数:method=ajax&val=xxx,服务器可以通过request.getParameter()来获取 //data:{method:"ajaxTest",val:value}, data: { name: $("#name").val(), studentId: $("#studentId").val(), }, async: true, //是否为异步请求 cache: false, //是否缓存结果 type: "POST", //请求方式为POST dataType: "json", //服务器返回的数据是什么类型 success: function(result){ //这个方法会在服务器执行成功是被调用 ,参数result就是服务器返回的值(现在是json类型) if(result){ alert("true"); }else{ alert("false"); } } }); });
web. xml 구성 코드:
<servlet> <description>This is the description of my J2EE component</description> <display-name>This is the display name of my J2EE component</display-name> <servlet-name>addStudents</servlet-name> <servlet-class>org.cms.students.addStudents</servlet-class> </servlet> <servlet-mapping> <servlet-name>addStudents</servlet-name> <url-pattern>/addStudents.do</url-pattern> </servlet-mapping>
addStudents.java 코드(POST 제출 방법 사용):
public void doPost(HttpServletRequest request, HttpServletResponse response) throws ServletException, IOException { PrintWriter out = response.getWriter(); String name=request.getParameter("name"); System.out.println(name); System.out.println("123456789"); out.print("false"); }
ajax 제출 양식
위 구성을 통과한 후 다음을 입력합니다. 학생 이름 그런 다음 양식을 제출했지만 이름과 "123456789"라는 문자열이 myeclipse 콘솔에 인쇄되지 않았습니다. 그런 다음 미친 검사를 시작하여 n 번 확인했지만 여전히 오류가 발생한 위치를 알 수 없었습니다. 우연히 문제를 발견했습니다. Ajax 코드 블록 뒤에 경고() 문을 추가했는데 기적이 일어났습니다. 브라우저에 해당 내용이 팝업되고 myeclipse 콘솔에 "123456789"라는 문자열이 인쇄되었습니다. 많은 블로그 공식 문서를 살펴본 후 모든 것이 JQuery ajax의 동기 및 비동기 제출 이유라는 것을 깨달았습니다.
먼저 JQuery ajax 방식을 이해해보자:
비동기의 이해: ajax 부분까지 코드가 실행될 때, ajax 이후에 사용할 외부 코드가 있으면 함께 실행된다. 이때 ajax의 반환 값은 ajax의 async 속성이 true(즉, 현재 ajax는 비동기임)이면 후속 외부 코드에서는 ajax의 반환 값을 얻는 것이 불가능하게 설정될 수만 있습니다. 즉, ajax의 async 속성이 true인 경우에만 ajax 부분이 실행되고 이후 코드가 실행될 때 관계에 연속성이 있게 되며 이러한 방식으로 반환 값을 얻을 수 있습니다. .
그럼 async를 false로 설정했더니 정말 문제가 해결됐는데, 왜 경고문을 추가했는데도 비동기적으로도 이름과 문자열이 출력되는지 아직도 모르겠네요?
계속해서 정보를 확인하고 내 자신의 요약은 다음과 같습니다(모든 전문가의 조언을 환영합니다):
1. Async: true: 제출 버튼을 클릭하면 클릭 이벤트의 코드 문이 표시됩니다. 실행되고 ajax가 실행될 때 비동기식으로 실행되기 때문에 이후 명령문이 없기 때문에 후속 명령문의 실행을 차단하지 않으므로 클릭 실행을 완료하기 전에 ajax가 종료될 수 있습니다. 이벤트가 발생하여 이름과 문자열이 출력되지 않았습니다. ajax 뒤에 경고 문을 추가하면 여기에서 클릭 이벤트가 차단됩니다. 이때 ajax는 실행할 시간이 충분하므로 콘솔에서 이름과 문자열을 출력할 수 있습니다. 외부 클릭 이벤트를 제거하고 ajax를 직접 실행해 보았는데 이때 동기식, 비동기식 상관없이 이름과 문자열이 출력되는 것을 보니 제 추측이 맞네요.
2. async:false인 경우: submit 버튼을 클릭하면 click 이벤트에 있는 코드문도 실행됩니다. ajax가 실행되면 동기적으로 실행되기 때문에 계속하기 전에 ajax가 성공적으로 반환될 때까지 기다려야 합니다. 다음 코드를 실행하면 당연히 이름과 문자열이 인쇄될 수 있습니다.

핫 AI 도구

Undresser.AI Undress
사실적인 누드 사진을 만들기 위한 AI 기반 앱

AI Clothes Remover
사진에서 옷을 제거하는 온라인 AI 도구입니다.

Undress AI Tool
무료로 이미지를 벗다

Clothoff.io
AI 옷 제거제

AI Hentai Generator
AI Hentai를 무료로 생성하십시오.

인기 기사

뜨거운 도구

Atom Editor Mac 버전 다운로드
가장 인기 있는 오픈 소스 편집기

Eclipse용 SAP NetWeaver 서버 어댑터
Eclipse를 SAP NetWeaver 애플리케이션 서버와 통합합니다.

스튜디오 13.0.1 보내기
강력한 PHP 통합 개발 환경

SecList
SecLists는 최고의 보안 테스터의 동반자입니다. 보안 평가 시 자주 사용되는 다양한 유형의 목록을 한 곳에 모아 놓은 것입니다. SecLists는 보안 테스터에게 필요할 수 있는 모든 목록을 편리하게 제공하여 보안 테스트를 더욱 효율적이고 생산적으로 만드는 데 도움이 됩니다. 목록 유형에는 사용자 이름, 비밀번호, URL, 퍼징 페이로드, 민감한 데이터 패턴, 웹 셸 등이 포함됩니다. 테스터는 이 저장소를 새로운 테스트 시스템으로 간단히 가져올 수 있으며 필요한 모든 유형의 목록에 액세스할 수 있습니다.

SublimeText3 중국어 버전
중국어 버전, 사용하기 매우 쉽습니다.

뜨거운 주제



