जेएसपी - डिबगिंग
इस अध्याय में, हम एक जेएसपी डिबगिंग पर चर्चा करेंगे। जेएसपी और सर्वलेट्स का परीक्षण करना हमेशा कठिन होता है। JSP और सर्वलेट्स में क्लाइंट / सर्वर इंटरैक्शन की एक बड़ी मात्रा शामिल होती है, जिससे त्रुटियों की संभावना होती है लेकिन पुन: उत्पन्न करने में मुश्किल होती है।
निम्नलिखित कुछ संकेत और सुझाव हैं जो आपके डीबगिंग में आपकी सहायता कर सकते हैं।
System.out.println () का उपयोग करना
System.out.println()कोड के एक निश्चित टुकड़े को निष्पादित किया जा रहा है या नहीं, यह जांचने के लिए एक मार्कर के रूप में उपयोग करना आसान है। हम चर मानों को भी प्रिंट कर सकते हैं। निम्नलिखित अतिरिक्त बिंदुओं पर विचार करें -
चूंकि सिस्टम ऑब्जेक्ट कोर जावा ऑब्जेक्ट का हिस्सा है, इसलिए इसे किसी भी अतिरिक्त कक्षाओं को स्थापित करने की आवश्यकता के बिना हर जगह इस्तेमाल किया जा सकता है। यह भी शामिल हैServlets, JSP, RMI, EJB's, ordinary Beans तथा classes, तथा standalone applications।
ब्रेकपॉइंट पर रुकने की तुलना में, लिखना System.out आवेदन के सामान्य निष्पादन प्रवाह के साथ ज्यादा हस्तक्षेप नहीं करता है, जो कि बहुत महत्वपूर्ण है जब नकल महत्वपूर्ण है।
निम्नलिखित सिंटैक्स का उपयोग करना है System.out.println() -
System.out.println("Debugging message");
निम्नलिखित उदाहरण दिखाता है कि कैसे उपयोग करना है System.out.print() -
<%@taglib prefix = "c" uri = "http://java.sun.com/jsp/jstl/core" %>
<html>
<head><title>System.out.println</title></head>
<body>
<c:forEach var = "counter" begin = "1" end = "10" step = "1" >
<c:out value = "${counter-5}"/></br>
<% System.out.println( "counter = " + pageContext.findAttribute("counter") ); %>
</c:forEach>
</body>
</html>
उपरोक्त JSP पर पहुँचें, ब्राउज़र निम्न परिणाम दिखाएगा -
-4
-3
-2
-1
0
1
2
3
4
5
यदि आप टॉमकैट का उपयोग कर रहे हैं, तो आप इन पंक्तियों को अंतिम छोर तक जोड़ देंगे stdout.log लॉग निर्देशिका में।
counter = 1
counter = 2
counter = 3
counter = 4
counter = 5
counter = 6
counter = 7
counter = 8
counter = 9
counter = 10
इस तरह आप सिस्टम लॉग में चर और अन्य जानकारी ला सकते हैं जिसका विश्लेषण समस्या के मूल कारण या विभिन्न कारणों से किया जा सकता है।
JDB लकड़हारा का उपयोग करना
J2SEलॉगिंग फ्रेमवर्क JVM में चलने वाले किसी भी वर्ग के लिए लॉगिंग सेवाएं प्रदान करने के लिए डिज़ाइन किया गया है। हम किसी भी जानकारी को लॉग करने के लिए इस ढांचे का उपयोग कर सकते हैं।
हमें JDK लकड़हारा एपीआई का उपयोग करके उपरोक्त उदाहरण को फिर से लिखना चाहिए -
<%@taglib prefix = "c" uri = "http://java.sun.com/jsp/jstl/core" %>
<%@page import = "java.util.logging.Logger" %>
<html>
<head><title>Logger.info</title></head>
<body>
<% Logger logger = Logger.getLogger(this.getClass().getName());%>
<c:forEach var = "counter" begin = "1" end = "10" step = "1" >
<c:set var = "myCount" value = "${counter-5}" />
<c:out value = "${myCount}"/></br>
<% String message = "counter = "
+ pageContext.findAttribute("counter") + "myCount = "
+ pageContext.findAttribute("myCount");
logger.info( message );
%>
</c:forEach>
</body>
</html>
उपरोक्त कोड ब्राउज़र पर और stdout.log में समान परिणाम उत्पन्न करेगा, लेकिन आपके पास अतिरिक्त जानकारी होगी stdout.log। हम उपयोग करेंगेinfoलकड़हारा की विधि क्योंकि और संदेश केवल सूचना के उद्देश्य के लिए लॉग इन करें। निम्नलिखित stdout.log फ़ाइल का एक स्नैपशॉट है -
24-Sep-2010 23:31:31 org.apache.jsp.main_jsp _jspService
INFO: counter = 1 myCount = -4
24-Sep-2010 23:31:31 org.apache.jsp.main_jsp _jspService
INFO: counter = 2 myCount = -3
24-Sep-2010 23:31:31 org.apache.jsp.main_jsp _jspService
INFO: counter = 3 myCount = -2
24-Sep-2010 23:31:31 org.apache.jsp.main_jsp _jspService
INFO: counter = 4 myCount = -1
24-Sep-2010 23:31:31 org.apache.jsp.main_jsp _jspService
INFO: counter = 5 myCount = 0
24-Sep-2010 23:31:31 org.apache.jsp.main_jsp _jspService
INFO: counter = 6 myCount = 1
24-Sep-2010 23:31:31 org.apache.jsp.main_jsp _jspService
INFO: counter = 7 myCount = 2
24-Sep-2010 23:31:31 org.apache.jsp.main_jsp _jspService
INFO: counter = 8 myCount = 3
24-Sep-2010 23:31:31 org.apache.jsp.main_jsp _jspService
INFO: counter = 9 myCount = 4
24-Sep-2010 23:31:31 org.apache.jsp.main_jsp _jspService
INFO: counter = 10 myCount = 5
सुविधा कार्यों का उपयोग करके विभिन्न स्तरों पर संदेश भेजे जा सकते हैं severe(), warning(), info(), config(), fine(), finer(), तथा finest()। यहाँ बेहतरीन () विधि का उपयोग बेहतरीन जानकारी लॉग करने के लिए किया जा सकता है और गंभीर () विधि का उपयोग गंभीर जानकारी लॉग करने के लिए किया जा सकता है।
आप लॉगजीजे फ्रेमवर्क का उपयोग उनके गंभीरता स्तरों और महत्व के आधार पर विभिन्न फ़ाइलों में संदेशों को लॉग करने के लिए कर सकते हैं ।
डिबगिंग उपकरण
नेटबीन्स एक स्वतंत्र और ओपन-सोर्स जावा इंटीग्रेटेड डेवलपमेंट एनवायरनमेंट है जो जेएसपी और सर्वलेट विनिर्देशों का समर्थन करने वाले स्टैंडअलोन जावा अनुप्रयोगों और वेब अनुप्रयोगों के विकास का समर्थन करता है और इसमें एक जेएसपी डीबगर भी शामिल है।
NetBeans निम्नलिखित मूल डिबगिंग कार्यात्मकताओं का समर्थन करता है -
- Breakpoints
- कोड के माध्यम से कदम
- Watchpoints
आप के लिए रेफरी कर सकते हैं NetBeans documentation डिबगिंग कार्यात्मकताओं के ऊपर समझने के लिए।
JDB डीबगर का उपयोग करना
आप उसी के साथ JSP और सर्वलेट डीबग कर सकते हैं jdb कमांड का उपयोग आप एक एप्लेट या एप्लिकेशन को डीबग करने के लिए करते हैं।
JSP या सर्वलेट को डीबग करने के लिए, आप डीबग कर सकते हैं sun.servlet.http.HttpServer, तब अवलोकन करें कि HttpServer एक ब्राउज़र से किए गए HTTP अनुरोधों के जवाब में JSP / सर्वलेट्स निष्पादित करता है। यह बहुत ही समान है कि कैसे एप्लेट को डिबग किया जाता है। अंतर यह है कि एप्लेट्स के साथ, वास्तविक प्रोग्राम डिबग किया जा रहा हैsun.applet.AppletViewer।
अधिकांश डिबगर इस विवरण को स्वचालित रूप से एप्लेट डिबग करने का तरीका जानते हुए छिपाते हैं। जब तक वे जेएसपी के लिए ऐसा नहीं करते, आपको निम्नलिखित पर विचार करके अपने डिबगर की मदद करनी होगी -
अपना डिबगर का क्लासपैथ सेट करें। यह आपको खोजने में मदद करता हैsun.servlet.http.Http-Server और संबंधित कक्षाएं।
अपना डिबगर का क्लासपैथ सेट करें। यह आपके जेएसपी और सहायता वर्गों को खोजने में मदद करता है, आमतौर परROOT\WEB-INF\classes।
एक बार जब आप उचित वर्गपथ निर्धारित कर लें, तो डिबगिंग शुरू करें sun.servlet.http.HttpServer। आप जिस भी जेएसपी में डिबगिंग में रुचि रखते हैं, उसमें ब्रेकप्वाइंट सेट कर सकते हैं, फिर दिए गए जेएसपी के लिए HttpServer में अनुरोध करने के लिए एक वेब ब्राउज़र का उपयोग करें(http://localhost:8080/JSPToDebug)। यहां निष्पादन ब्रेकपॉइंट पर बंद हो जाता है।
टिप्पणियों का उपयोग करना
आपके कोड की टिप्पणियां विभिन्न तरीकों से डिबगिंग प्रक्रिया में मदद कर सकती हैं। डिबगिंग प्रक्रिया में टिप्पणियों का उपयोग कई अन्य तरीकों से किया जा सकता है।
JSP जावा टिप्पणियों और का उपयोग करता है single line (// ...) तथा multiple line (/* ... */)टिप्पणियों का उपयोग आपके जावा कोड के कुछ हिस्सों को अस्थायी रूप से हटाने के लिए किया जा सकता है। यदि बग गायब हो जाता है, तो जिस कोड पर आपने टिप्पणी की है, उस पर करीब से नज़र डालें और समस्या का पता लगाएं।
क्लाइंट और सर्वर हेडर
कभी-कभी जब एक जेएसपी अपेक्षा के अनुरूप व्यवहार नहीं करता है, तो यह कच्चे HTTP अनुरोध और प्रतिक्रिया को देखने के लिए उपयोगी है। यदि आप HTTP की संरचना से परिचित हैं, तो आप अनुरोध और प्रतिक्रिया पढ़ सकते हैं और देख सकते हैं कि वास्तव में उन हेडर के साथ क्या हो रहा है।
महत्वपूर्ण डिबगिंग युक्तियाँ
यहाँ JSP डिबगिंग पर कुछ और डिबगिंग सुझावों की एक सूची दी गई है -
ब्राउज़र को उस पृष्ठ की कच्ची सामग्री दिखाने के लिए कहें जो वह प्रदर्शित कर रहा है। यह स्वरूपण समस्याओं की पहचान करने में मदद कर सकता है। यह आमतौर पर दृश्य मेनू के तहत एक विकल्प है।
सुनिश्चित करें कि पृष्ठ के पूर्ण पुनः लोड के लिए ब्राउज़र पिछले अनुरोध के आउटपुट को कैशिंग नहीं कर रहा है। साथ मेंNetscape Navigator, उपयोग Shift-Reload; साथ मेंInternet Explorer उपयोग Shift-Refresh।