GWT-디버깅 애플리케이션

GWT는 클라이언트 측 및 서버 측 코드를 디버깅하는 탁월한 기능을 제공합니다.

개발 모드 중에 GWT 애플리케이션은 Java 코드 기반이며 JavaScript로 변환되지 않습니다.

애플리케이션이 개발 모드에서 실행 중일 때 JVM (Java Virtual Machine)은 실제로 브라우저 창에 연결하는 GWT 기능을 사용하여 컴파일 된 Java 바이트 코드로 애플리케이션 코드를 실행합니다.

GWT는 브라우저 기반 플러그인을 사용하여 JVM에 연결합니다.

따라서 개발자는 Java 기반 IDE를 사용하여 클라이언트 측 GWT 코드와 서버 측 코드를 모두 디버깅 할 수 있습니다.

이 기사에서는 Eclipse를 사용하여 GWT 클라이언트 코드를 디버깅하는 사용법을 보여줍니다. 다음 작업을 수행합니다.

  • 코드에 중단 점을 설정하고 BreakPoint Explorer에서 확인하십시오.
  • 디버깅하는 동안 코드를 한 줄씩 살펴보십시오.
  • 변수 값을 봅니다.
  • 모든 변수의 값을 검사하십시오.
  • 표현식의 값을 검사하십시오.
  • 일시 중단 된 스레드의 스택 프레임을 표시합니다.

디버깅 예

이 예제는 GWT 애플리케이션 디버깅을 보여주는 간단한 단계를 안내합니다. 다음 단계에 따라 GWT에서 생성 한 GWT 애플리케이션을 업데이트합니다 -애플리케이션 생성 장-

단계 기술
1 GWT- 애플리케이션 만들기 장에 설명 된대로 com.tutorialspoint 패키지 아래에 HelloWorld 라는 이름으로 프로젝트를 만듭니다 .
2 아래 설명과 같이 HelloWorld.gwt.xml , HelloWorld.css , HelloWorld.htmlHelloWorld.java 를 수정하십시오 . 나머지 파일은 변경하지 마십시오.
애플리케이션을 컴파일하고 실행하여 구현 된 논리의 결과를 확인합니다.

다음은 수정 된 모듈 설명 자의 내용입니다. src/com.tutorialspoint/HelloWorld.gwt.xml.

<?xml version = "1.0" encoding = "UTF-8"?>
<module rename-to = 'helloworld'>
   <!-- Inherit the core Web Toolkit stuff.                        -->
   <inherits name = 'com.google.gwt.user.User'/>

   <!-- Inherit the default GWT style sheet.                       -->
   <inherits name = 'com.google.gwt.user.theme.clean.Clean'/>

   <!-- Specify the app entry point class.                         -->
   <entry-point class = 'com.tutorialspoint.client.HelloWorld'/>

   <!-- Specify the paths for translatable code                    -->
   <source path = 'client'/>
   <source path = 'shared'/>

</module>

다음은 수정 된 스타일 시트 파일의 내용입니다. war/HelloWorld.css.

body {
   text-align: center;
   font-family: verdana, sans-serif;
}

h1 {
   font-size: 2em;
   font-weight: bold;
   color: #777777;
   margin: 40px 0px 70px;
   text-align: center;
}

.gwt-Label{ 
   font-size: 150%; 
   font-weight: bold;
   color:red;
   padding:5px;
   margin:5px;
}

다음은 수정 된 HTML 호스트 파일의 내용입니다. war/HelloWorld.html 두 개의 버튼을 수용합니다.

<html>
   <head>
      <title>Hello World</title>
      <link rel = "stylesheet" href = "HelloWorld.css"/>
      <script language = "javascript" src = "helloworld/helloworld.nocache.js">
      </script>
   </head>

   <body>
      <h1>Debugging Application Demonstration</h1>
      <div id = "gwtContainer"></div>
   </body>
</html>

Java 파일의 다음 내용을 갖도록합시다 src/com.tutorialspoint/HelloWorld.java 이를 사용하여 GWT 코드의 디버깅 기능을 시연합니다.

package com.tutorialspoint.client;

import com.google.gwt.core.client.EntryPoint;
import com.google.gwt.event.dom.client.ClickEvent;
import com.google.gwt.event.dom.client.ClickHandler;
import com.google.gwt.event.dom.client.KeyCodes;
import com.google.gwt.event.dom.client.KeyUpEvent;
import com.google.gwt.event.dom.client.KeyUpHandler;
import com.google.gwt.user.client.Window;
import com.google.gwt.user.client.ui.Button;
import com.google.gwt.user.client.ui.DecoratorPanel;
import com.google.gwt.user.client.ui.HasHorizontalAlignment;
import com.google.gwt.user.client.ui.HorizontalPanel;
import com.google.gwt.user.client.ui.Label;
import com.google.gwt.user.client.ui.RootPanel;
import com.google.gwt.user.client.ui.TextBox;
import com.google.gwt.user.client.ui.VerticalPanel;

public class HelloWorld implements EntryPoint {
	
   public void onModuleLoad() {
      /*create UI */
      final TextBox txtName = new TextBox(); 
      txtName.setWidth("200");
      txtName.addKeyUpHandler(new KeyUpHandler() {
         @Override
         public void onKeyUp(KeyUpEvent event) {
            if(event.getNativeKeyCode() == KeyCodes.KEY_ENTER){
               Window.alert(getGreeting(txtName.getValue()));
            }				
         }
      });
      Label lblName = new Label("Enter your name: ");

      Button buttonMessage = new Button("Click Me!");

      buttonMessage.addClickHandler(new ClickHandler() {			
      @Override
      public void onClick(ClickEvent event) {
         Window.alert(getGreeting(txtName.getValue()));
      }});

      HorizontalPanel hPanel = new HorizontalPanel();	
      hPanel.add(lblName);
      hPanel.add(txtName);
      hPanel.setCellWidth(lblName, "130");

      VerticalPanel vPanel = new VerticalPanel();
      vPanel.setSpacing(10);
      vPanel.add(hPanel);
      vPanel.add(buttonMessage);
      vPanel.setCellHorizontalAlignment(buttonMessage, 
      HasHorizontalAlignment.ALIGN_RIGHT);

      DecoratorPanel panel = new DecoratorPanel();
      panel.add(vPanel);

      // Add widgets to the root panel.
      RootPanel.get("gwtContainer").add(panel);
   }  
   
   public String getGreeting(String name){
      return "Hello "+name+"!";
   }
}

1 단계-중단 점 배치

첫 번째 줄에 중단 점을 놓습니다. onModuleLoad() HelloWorld.java의

2 단계-애플리케이션 디버그

이제

디버그 애플리케이션 메뉴를 클릭 하고HelloWorld 응용 프로그램을 디버깅합니다.

모든 것이 정상이면 아래와 같이 URL이 포함 된 Eclipse에서 GWT 개발 모드가 활성화되어 있어야합니다. URL을 두 번 클릭하여 GWT 애플리케이션을 엽니 다.

애플리케이션이 시작 되 자마자 진입 점 메서드의 첫 번째 줄에 중단 점을 배치 했으므로 Eclipse 중단 점에 초점이 맞춰진 것을 볼 수 있습니다.

일시 중단 된 스레드에 대한 스택 추적을 볼 수 있습니다.

표현식의 값을 볼 수 있습니다.

배치 된 중단 점 목록을 볼 수 있습니다.

이제 onModuleLoad () 메서드의 마지막 줄에 도달 할 때까지 F6 키를 계속 누릅니다. 기능 키에 대한 참조로 F6은 코드를 한 줄씩 검사하고 F5는 더 안쪽으로 들어가며 F8은 응용 프로그램을 다시 시작합니다. 이제 onModuleLoad () 메서드의 모든 변수 값 목록을 볼 수 있습니다.

GWT 클라이언트 코드는 Java 애플리케이션을 디버깅 할 수있는 것과 동일한 방식으로 디버깅 할 수 있습니다. 중단 점을 모든 줄에 배치하고 GWT의 디버깅 기능을 사용합니다.