ASP Procedure

ASP에서는 VBScript와 JavaScript 간 프로시져를 상호 호출 가능함.

 

Procedure

다음과 같은 프로시져 기능이 있을 수 있음.

VBScript Procedure

  <!DOCTYPE html>
  <html>
  <head>
    <%
      sub vbproc( x, y )
        response.write( "x * y = " & x * y )
      end sub
    %>
  </head>
  <body>
    <p>Result : <%call vbproc( 3, 4 )%></p>
  </body>
  </html>

다른 스크립팅 언어로 프로시져 / 함수를 작성하려면 <html> 태그 위에 <%@ language="{사용할 언어}" %>를 넣어주면 됨.

js procedure

  <%@ language="javascript" %>
  <!DOCTYPE html>
  <html>
  <head>
    <%
      function jsproc( x, y ) {
        Response.Write( "x * y = " + x * y );
      }
    %>
  </head>
  <body>
    <p>Result : <% jsproc( 3, 4 ); %></p>
  </body>
  </html>

 


VBScript와 JS의 차이점

VBScript로 작성된 ASP 파일에서 VBScript 또는 JS 프로시져를 호출할 때 프로시져 이름 뒤에 call 키워드를 사용할 수 있음.
프로시져에 매개변수가 필요한 경우 call 키워드를 사용할 때 매개변수 목록을 괄호로 묶어야 함. call 키워드를 생략하는 경우 매개변수 목록을 괄호로 묶지 않아야 함.
프로시져에 매개변수가 없으면 괄호는 선택사항임.

JS로 작성된 ASP 파일에서 JS 또는 VBScript 프로시져를 호출할 때 항상 프로시져 이름 뒤에 괄호를 사용해야 함.

 


VBScript Procedure

VBScript에는 두가지 종류의 프로시져가 있음.

  • Sub Procedure
  • Function Procedure

VBScript Sub Procedure

  • sub, end sub 으로 묶인 일련의 문장임.
  • 작업을 하지만 값을 반환하지 않음.
  • 인수를 취할 수 있음.
  sub mysub() 
    some statements
  end sub
  sub mysub( arg1, arg2 ) 
    some statements
  end sub
  <!DOCTYPE html>
  <html>
  <body>
    <%
      sub mysub() 
        response.write( "written by a sub procedure.<br/>" )
      end sub

      response.write( "writtten by the script.<br/>" )
      call mysub()
      call mysub
      mysub()
      mysub
    %>
  </body>
  </html>

 

VBScript Function Procedure

  • function, end function으로 묶인 일련의 문장.
  • 작업을 하고 값을 반환함.
  • 이름에 값을 할당하여 값을 반환함.
  • 호출 프로시져에 의새 인수를 취할 수 있음.
  • 인수가 없으면 빈 괄호 ()를 포함 해야함.
  function func()
    some statements
    func = some value
  end function
  function func( arg1, arg2 )
    some statements
    func = some value
  end function

 

프로시져 호출

  <!DOCTYPE html>
  <html>
  <body>
    <%
      ' 인수 a, b를 받아서 그 합을 반환하는 func
      function func( a, b )
        func = a + b
      end function

      response.write( func( 5, 9 ) )
    %>
  </body>
  </html>

 

VBScript를 이용하여 프로시져 호출

ASP에서 javascript 와 VBScript 에서 만든 프로시져를 모두 호출하는 방법

  <!DOCTYPE html>
  <html>
  <head>
    <%
      sub vbproc( x, y )
        response.write( x * y )
      end sub
    %>
    <script language="javascript" runat="server">
      function jsproc( x, y ) {
        Response.Write( x * y );
      }
    </script>
  </head>
  <body>
    <p> call vbproc : <%call vbproc( 3, 4 )%></p>
    <p> call jsproc : <%call jsproc( 3, 4 )%></p>
  </body>
  </html>

 


728x90
반응형

'WEB > ASP' 카테고리의 다른 글

[ASP] 반복문  (0) 2021.08.26
[ASP] 조건문  (0) 2021.08.26
[ASP] 변수  (0) 2021.08.26
[ASP] 문법  (0) 2021.08.25
[ASP] Intro  (0) 2021.08.25

ASP 변수

변수의 기본 개념은 다르지 않음.


예제

변수 선언

변수를 선언하고 변수에 값을 할당하고 텍스트에서 값을 출력하는 방법

  <!DOCTYPE html>
  <html>
  <body>
    <%
      dim name
      name = "ASDF Stupid"
      response.write("My name is: " & name)
    %>
  </body>
  </html>

반복문

  <% @CODEPAGE="65001" language="vbscript" %>
  <!DOCTYPE html>
  <head>
    <meta http-equiv="Content-Type" content="text/html; charset=UTF-8">
  </head>
  <html>
  <body>
    <%
      dim i
      for i = 1 to 6
        response.write( "<h" & i & ">Heading " & i & "</h" & i & ">" )
      next
    %>
  </body>
  </html>

배열 생성

  <!DOCTYPE html>
  <html>
  <body>
    <%
      dim famname(5), i
      famname(0) = "Tov Lo"
      famname(1) = "Flume"
      famname(2) = "Heize"
      famname(3) = "쓰레기 같은"
      famname(4) = "ASP"
      famname(5) = "Borge"

      for i = 0 to 5
        response.write(famname(i) & "<br>")
      next
    %>
  </body>
  </html>

VBScript를 이용한 시간 출력

서버의 시간 출력

  <% @CODEPAGE="65001" language="vbscript" %>
  <!DOCTYPE html>
  <head>
    <meta http-equiv="Content-Type" content="text/html; charset=UTF-8">
  </head>
  <html>
  <body>
    <%
      dim h
      h = hour( now() )

      response.write( "<p>" & now() & "</p>" )

      if h < 12 then
        response.write( "Good Morning!" )
      else
        response.write( "Good Day!" )
      end if
    %>
  </body>
  </html>

JavaScript를 이용한 시간 출력

위의 예제와 같지만 JS를 이용함.
W3C예제를 따라한건데, javascript를 사용하는건지 JScript를 사용하는건지 솔직히 분간은 안됨.

  <%@ language="javascript" %>
  <!DOCTYPE html>
  <html>
  <body>
    <%
      var d = new Date();
      var h = d.getHours();

      Response.Write( "<p>" + d + "</p>" );

      if ( h < 12 ) {
        Response.Write("Good Morning!");
      } else {
        Response.Write("Good Day!");
      }
    %>
  </body>
  </html>

변수 생성 및 변경

  <!DOCTYPE html>
  <html>
  <body>
  <%
    dim asdf
    asdf = "Flume"

    response.write(asdf)

    response.write("<br>")

    asdf = "Tove Lo"
    response.write(asdf)
  %>
  </body>
  </html>

대수학

x = 5, y = 6, z = x + y
x와 y에 값을 저장할 수 있고, 이 정보를 이용하여 z의 값 11을 구할 수 있음.
이런 x, y, z를 변수라고 함.

VBScript 변수

VBScript의 변수는 값이나 표현식을 저장하는 데 사용됨.
변수는 x와 같은 짧은 이름이나 carname과 같이 더 명시적인 이름을 사용할 수 있음.

  • VBScript의 변수 작명 규칙
    • 문자로 시작해야 함
    • .를 포함할 수 없음
    • 255자를 넘길 수 없음

VBScript의 모든 변수는 타입이 지정되어 있지 않은 variant 유형임

VBScript 변수 선언

VBScript에서 변수를 생성하는 것은 선언 변수라고 함.
dim, public, private 키워드를 이용해서 VBScript 변수를 선언할 수 있음.

  dim x
  dim carname

두개의 변수 x와 carname을 만들었음.
스크립트에서 이름을 사용해서 변수를 선언 할 수 있음.

  carname = "Porsche"

변수에 값도 할당했음. 변수 이름은 carname, 값은 Porsche 임. 스크립트에서 변수 이름의 철자를 잘못 입력 할 수 있고, 코드가 실행될 때 의도하지 않은 결과를 초래할 수 있음.
carname 변수를 carnime으로 잘못 입력하면 스크립트는 carnime라는 새 변수를 자동으로 생성함.
스크립트가 이런 의도치 않은 변수 생성을 막으려면 Option Explicit 옵션을 넣을 수 있음.
스크립트 맨 위에 Option Explicit을 넣으면 됨.

  <%@ Language=VBScript %>
  <% Option Explicit %>
  <!DOCTYPE html>
  <html>
  <body>
    <%
      dim x
      dim carname

      carname = "Porsche"

      response.write( "carname : " & carname & "<br/>" )

      ' Option Explicit 설정이 있어서 아래 구문은 에러가 생김
      carnime = "carnime"


      public a
      a = "public"
      response.write( "a : " & a & "<br/>" )
      private c
      c = "private"
      response.write( "c : " & c & "<br/>" )
    %>
  </body>
  </html>
  carname : Porsche
  Microsoft VBScript 런타임 오류 오류 '800a01f4'

  변수가 정의되지 않았습니다.: 'carnime'

  /test/test/example.asp, 줄 15
  • public, private 차이는 알 수 없네

VBScript 배열 변수

배열 변수는 단일 변수에 여러 값을 저장하는데 사용함.

  <!DOCTYPE html>
  <html>
  <body>
    <%
      ' 2차원 배열 선언
      dim arr(2, 2)

      ' 할당
      arr( 0, 0 ) = "Volvo"
      arr( 0, 1 ) = "BMW"
      arr( 0, 2 ) = "Ford"

      arr( 1, 0 ) = "Apple"
      arr( 1, 1 ) = "Orange"
      arr( 1, 2 ) = "Banana"

      arr( 2, 0 ) = "Coke"
      arr( 2, 1 ) = "Pepsi"
      arr( 2, 2 ) = "Sprite"

      for i = 0 to 2
        response.write( "<p>" )
          for j = 0 to 2
            ' 배열에서 인덱스로 값 출력
            response.write( arr(i, j) & "<br />" )
          next
        response.write( "</br>" )
      next
    %>
  </body>
  </html>

변수의 수명

프로시져 외부에서 선언된 변수는 ASP 파일의 모든 스크립트에서 엑세스하고 변경 가능함.

프로시져 내부에서 선언된 변수는 프로시져가 실행될 때마다 생성되고 소멸함. 프로시져 외부의 어떤 스크립트도 변수에 엑세스하거나 변수를 변경할 수 없음.

둘 이상의 ASP 파일에 엑세스할 수 있는 변수를 선언하려면 세션 변수 또는 어플리케이션 변수로 선언해야 함.

세션변수

세션 변수는 단일 사용자에 대한 정보를 저장하는 데 사용되며 하나의 어플리케이션의 모든 페이지에서 사용할 수 있음.
일반적으로 세션 변수에 저장되는 정보는 이름, ID 및 기본 설정임.

어플리케이션 변수

어플리케이션 변수는 한 어플리케이션의 모든 페이지에서 사용 가능.
어플리케이션 변수는 하나의 특정 어플리케이션에 있는 모든 사용자에 대한 정보를 저장하는 데 사용함.


출처 : https://www.w3schools.com/asp/asp_variables.asp

728x90
반응형

'WEB > ASP' 카테고리의 다른 글

[ASP] 조건문  (0) 2021.08.26
[ASP] Procedure  (0) 2021.08.26
[ASP] 문법  (0) 2021.08.25
[ASP] Intro  (0) 2021.08.25
[ASP] Classic ASP 입문  (1) 2021.08.25

ASP Syntax

ASP는 VBScript를 사용함.

ASP의 기본 스크립팅 언어는 VBScript임.
스크립팅 언어는 경량 프로그래밍 언어임.
VBScript는 MS Visual Basic의 라이트 버젼임.

 

ASP 파일

ASP 파일은 일반적인 HTML 파일일 수 있음.
또한 ASP 파일에는 서버 스크립트도 포함될 수 있음.
<% %>로 둘러 싸인 스크립트는 서버에서 실행됨.
Response.Write() 메소드는 ASP에 의해 HTML로 출력됨.
다음 코드는 "Hello World"를 출력함.

  <!DOCTYPE html>
  <html>
  <head></head>
  <body>
    <%
      response.write("Hello World!")
    %>
  </body>
  </html>

VBScript는 대소문자를 구분하지 않음.
Response.Write()response.write()와 같음.

 

ASP에서 JavaScript 사용

JS를 웹페이지의 스크립팅 언어로 설정하려면 페이지 상단에 언어 사양을 삽입해야 함.

  <%@ language="javascript" %>
  <!DOCTYPE html>
  <html>
  <head></head>
  <body>
    <%
      Response.Write("Hello World!")
    %>
  </body>
  </html>

javascript는 Response.Write()의 대소문자를 구분함.
앞으로의 ASP 튜토리얼은 VBScript를 사용함.

 

그 외

EX 03

Response.Write()=로 대치될 수 있음.

  <%="reponse.write() can replaced by `=`"%>

EX 04

HTML 태그역시 출력 가능함.

  <%="<h2>Using HTML tags to format the TEXT is available, FUCK!</h2>"%>

EX 04

HTML 태그 속성역시 출력 가능.

  <%="<p style='color: #0000FF;'>This text is styled.</p>"%>

 

 


VBScript 예제와 레퍼런스

 


출처 : https://www.w3schools.com/asp/asp_syntax.asp

728x90
반응형

'WEB > ASP' 카테고리의 다른 글

[ASP] 조건문  (0) 2021.08.26
[ASP] Procedure  (0) 2021.08.26
[ASP] 변수  (0) 2021.08.26
[ASP] Intro  (0) 2021.08.25
[ASP] Classic ASP 입문  (1) 2021.08.25

ASP Intro

ASP는 동적 웹 페이지를 만들기 위한 오래된 기술임.
ASP는 PHP 처럼 웹 서버에서 script를 실행하기 위한 기술임.

Show Example

  • ex :
      <!DOCTYPE html>
      <html>
      <body>
        <%
          response.write("My First ASP Script!")
        %>
      </body>
      </html>

ASP 란

  • Active Server Pages의 약자
  • MS의 기술
  • 웹 서버 내부에서 실행되는 프로그램

ASP 파일이란

  • .asp 확장자를 갖는 파일
  • HTML 파일과 비슷
  • HTML 외에 서버 스크립트를 포함하고 있음.
  • ASP 파일의 서버 스크립트는 서버에서 실행 됨.

ASP가 할 수 있는 것

  • 웹 페이지 편집, 변경, 콘텐츠 추가 또는 사용자 지정
  • HTML form에서 제출된 사용자 쿼리 또는 데이터에 응답
  • DB 또는 기타 서버 데이터에 엑세스하고 결과를 응답
  • 브라우져에서 ASP 코드를 볼 수 없으므로 웹 보안 제공
  • 빠르고 단순함

작동 원리

일반 HTML 파일을 요청하면 서버는 파일을 변환,
브라우져가 ASP 파일을 요청하면 ASP 파일을 읽고 파일에서 서버 스크립트를 실행하는 ASP 엔진에 요청을 전달.
ASP파일은 HTML로 응답됨.

reference and example

W3School에서 ASP의 기본 제공 개체 및 구성요소, 해당 속성 및 메소드에 대한 ASP reference를 제공함.
ASP 스크립트는 서버에서 실행되기 때문에 브라우져에서 ASP 코드를 볼 수 없음.
W3School에서 ASP 예제를 살펴볼 수 있음.

 

 

출처 : https://www.w3schools.com/asp/asp_introduction.asp

 

728x90
반응형

'WEB > ASP' 카테고리의 다른 글

[ASP] 조건문  (0) 2021.08.26
[ASP] Procedure  (0) 2021.08.26
[ASP] 변수  (0) 2021.08.26
[ASP] 문법  (0) 2021.08.25
[ASP] Classic ASP 입문  (1) 2021.08.25

Classic ASP 입문

ASP -> Spring 프로젝트에 투입되게 되었다.
프로젝트 진행 전 대략적으로 classic asp를 학습한다.
w3school의 튜토리얼을 대충 살펴보며,
개발 환경 셋팅과 기초 문법, DB 연결 프로젝트 구조 그리고 간단한 게시판 까지만 만들어 보도록 한다.


ASP and ASP.NET Tutorials

ASP는 Active Server Pages의 약자.
ASP 는 웹페이지 구축하기 위한 개발 프레임워크임.

ASP는 다양한 개발 모델을 지원함 :

  • classic asp
  • ASP.NET Web Form
  • ASP.NET MVC
  • ASP.NET WebPage
  • ASP.NET API
  • ASP.NET Core

ASP 기술

ASP와 ASP.NET은 서버사이드 기술임.
두 기술 모두 인터넷 서버에서 컴퓨터 코드를 실행할 수 있도록 함.
브라우져가 ASP / ASP.NET 파일을 요청하면 ASP 엔진은 파일을 읽고 파일의 코드를 실행한 다음 결과를 브라우져에 반환함.


classic ASP - Active Server Pages

ASP (Classic ASP 라고도 함)는 MS의 첫 서버사이트 스크립팅 언어로 도입됨.
클래식 ASP 페이지는 파일 확장자가 .asp 이고 일반적으로 VBScript로 작성됨.

 


기타 ASP 기술

  • ASP.NET :
    ASP.NET은 Classic ASP의 후속으로 2002년에 나옴.
    .aspx 확장자를 사용하며 일반적으로 C# 언어를 사용함.
    ASP.NET Core를 위해 ASP.NET 4 이후로 업데이트는 없음.
  • ASP.NET Web Pages :
    ASP.NET Web Pages는 SPA임.
    PHP와 Classic ASP와 매우 유사함.
    ASP.NET Core에 기본 스펙으로 들어가고 있음.
  • ASP.NET MVC :
    MVC 패턴의 ASP.NET
    ASP.NET Core에 기본 스펙으로 들어가고 있음.
  • ASP.NET Web API :
    API 어플리케이션 모델임.
    ASP.NET Core에 기본 스펙으로 들어가고 있음.
  • ASP.NET Web Form :
    이벤트 기반 응용 프로그램 모델임.
  • ASP.NET Core :
    2016년 출시.
    ASP.NET MVC, Web API, Web Pages를 하나의 프레임워크로 병합함.

출처 : https://www.w3schools.com/asp

728x90
반응형

'WEB > ASP' 카테고리의 다른 글

[ASP] 조건문  (0) 2021.08.26
[ASP] Procedure  (0) 2021.08.26
[ASP] 변수  (0) 2021.08.26
[ASP] 문법  (0) 2021.08.25
[ASP] Intro  (0) 2021.08.25

세션 유져 카운터 클래스

import javax.servlet.http.HttpSession;
import javax.servlet.http.HttpSessionEvent;
import javax.servlet.http.HttpSessionListener;
import org.slf4j.Logger;
import org.slf4j.LoggerFactory;

public class SessionUserCounter implements HttpSessionListener {
  private static Logger logger = LoggerFactory.getLogger(SessionUserCounter.class);
  
  //  총 접속자 수
  public static int count;
  
  public static int getCount() {
    return count;
  }

  @Override
  public void sessionCreated(HttpSessionEvent event) {
    //  세션이 생성될 때 세션객체를 꺼내옴.
    HttpSession session = event.getSession();
    count ++;
    logger.error("\n\tSESSION CREATED : {}, TOTAL ACCESSER : {}", session.getId(), count);
  }

  @Override
  public void sessionDestroyed(HttpSessionEvent event) {
    // 세션이 소멸될 때
    count--;
    if( count < 0 ) count = 0;
    
    HttpSession session = event.getSession();
    logger.error("\n\tSESSION DESTROYED : {}, TOTAL ACCESSER : {}", session.getId(), count);
  }
  
}

 

web.xml 설정

  <listener>
    <listener-class>{패키지 경로}.SessionUserCounter</listener-class>
  </listener>

 

Java 소스에서 클래스를 불러와서 사용해도 되고, JSP에서 class를 import 해서 사용해도 된다.

<%@ page language="java" contentType="text/html; charset=UTF-8" pageEncoding="UTF-8" trimDirectiveWhitespaces="true"
	import ="{패키지 경로}.SessionUserCounter"
%>
현재 접속자 수 : <%=SessionUserCounter.getCount()%>

 

 

스프링 허접이라 Lazy-Init SingleTon Pattern을 사용해야 하는지, 아니면 Listener에 등록된 객체이기 때문에 필요 없는지는 잘 모르겠다.

728x90
반응형

egovframework의 EgovHttpSessionBindingListener 클래스와 EgovMultiLoginPreventor 클래스로 중복 로그인 방지를 구현하던 중,
java.lang.illegalargumentexception setattribute non-serializable attribute ***에러가 발생했다.

session에 저장하기 위해선 해당 클래스 Serializable 클래스를 상속해 줘야 하는데, VO는 이미 상속이 되어 있었다.

VO 말고도 EgovHttpSessionBindingListener, EgovMultiLoginPreventor역시 Serializable 클래스를 상속해줘야 한다.

egov도 버젼 코드에 실수가 존재하나보다.

 

EgovHttpSessionBindingListener.java

package egovframework.com.utl.slm;

import java.io.Serializable;
import javax.servlet.http.HttpSessionBindingEvent;
import javax.servlet.http.HttpSessionBindingListener;
import org.slf4j.Logger;
import org.slf4j.LoggerFactory;

/**
 * @Class Name : EgovHttpSessionBindingListener.java
 * @Description : 중복 로그인 방지를 위해 사용자의 로그인 아이디와 세션을 제어하는 구현 클래스
 * @Modification Information
 *
 *               수정일 수정자 수정내용 ------- ------- ------------------- 2014.09.30 표준프레임워크 최초생성
 * @author YJ Kwon
 * @since 2014.09.30
 * @version 3.5
 */
public class EgovHttpSessionBindingListener implements HttpSessionBindingListener, Serializable {

  private static final long serialVersionUID = -6535453381287200501L;
  private static Logger logger = LoggerFactory.getLogger(EgovMultiLoginPreventor.class);

  /**
   * 사용자의 로그인 세션에 EgovHttpSessionBindingListener가 바인딩될 때 자동 호출되는 메소드로, 사용자 세션이 이미 존재하는지를 검사하여 하나의
   * 어플리케이션 내에서 하나의 세션만 유지되도록 한다
   */
  public void valueBound(HttpSessionBindingEvent event) {
    logger.error("\n\t!! VALUE BOUND !!");
    if (EgovMultiLoginPreventor.findByLoginId(event.getName())) {
      EgovMultiLoginPreventor.invalidateByLoginId(event.getName());
    }

    EgovMultiLoginPreventor.loginUsers.put(event.getName(), event.getSession());
  }


  /**
   * 
   * 로그아웃 혹은 세션타임아웃 설정에 따라 사용자 세션으로부터 EgovHttpSessionBindingListener가 제거될 때 자동 호출되는 메소드로, 사용자의 로그인
   * 아이디에 해당하는 세션을 ConcurrentHashMap에서 모두 제거한다
   */
  @Override
  public void valueUnbound(HttpSessionBindingEvent event) {
    logger.error("\n\t!! VALUE UNBOUND !!");
    EgovMultiLoginPreventor.loginUsers.remove(event.getName(), event.getSession());
  }

}

 

 

EgovMultiLoginPreventor.java

package egovframework.com.utl.slm;

import java.io.Serializable;
import java.util.Enumeration;
import java.util.concurrent.ConcurrentHashMap;

import javax.servlet.http.HttpSession;
import org.slf4j.Logger;
import org.slf4j.LoggerFactory;

/**
 * @Class Name : EgovMultiLoginPreventor.java
 * @Description : 중복 로그인 방지를 위해 사용자의 로그인 아이디와 세션 아이디를 관리하는 구현 클래스
 * @Modification Information
 *
 *               수정일 수정자 수정내용 ------- ------- ------------------- 2014.09.30 표준프레임워크 최초생성
 * @author YJ Kwon
 * @since 2014.09.30
 * @version 3.5
 */
public class EgovMultiLoginPreventor implements Serializable {

  private static final long serialVersionUID = 4012190701164146206L;

  private static Logger logger = LoggerFactory.getLogger(EgovMultiLoginPreventor.class);

  public static ConcurrentHashMap<String, HttpSession> loginUsers =
      new ConcurrentHashMap<String, HttpSession>();

  /**
   * 사용자의 로그인 아이디로 생성된 세션이 있는지를 확인한다
   */
  public static boolean findByLoginId(String loginId) {
    logger.error("\n\t>> loginUsers id : {} <<", loginId);
    return loginUsers.containsKey(loginId);
  }


  /**
   * 사용자의 로그인 아이디로 이미 존재하는 세션을 무효화한다
   */
  public static void invalidateByLoginId(String loginId) {
    Enumeration<String> e = loginUsers.keys();

    while (e.hasMoreElements()) {
      String key = (String) e.nextElement();

      logger.error("\n\t>> session key : {} <<", e.toString());
      if (key.equals(loginId)) {
        logger.error("\n\t:: SESSION INVALIDATE {} <<", loginId);
        loginUsers.get(key).invalidate();
      }
    }
  }

}
728x90
반응형

Linux에서 라인 수 카운트 하기.

  wc -l

해당 명령을 |와 함께 사용하면 됨.

EX

localhost_access_log.2021-06-22.txt 파일의 총 라인 수 카운트

  $ cat localhost_access_log.2021-06-22.txt |  wc -l
  90916

localhost_access_log.2021-06-22.txt 파일에서 특정 문자열이 포함된 라인 수 카운트

  # cat localhost_access_log.2021-06-22.txt | grep contractList.do | wc -l
  82
728x90
반응형

'OS > Linux' 카테고리의 다른 글

2025년 리눅스 마스터 자격증 시험일정과 준비 방법  (0) 2025.01.18
[Raspberry PI] 초기 셋팅  (0) 2022.03.07
[Linux] There are stopped jobs  (0) 2021.05.28
[Linux] 인터넷 속도 확인  (0) 2021.05.28
[Linux] top  (0) 2021.05.06

페이지 리로드 하는 방법이 필요해서 찾아보다 기록할 할 필요성있는 문제인거 같아서 남겨본다.

일반적인 js로 페이지 리로드 하기

일반적인 html을 리로드 할 때는 location.reload(); 하나면 된다.

frameset reload 하기

삽질은 여기서 시작 됬다.

    <!DOCTYPE HTML>
    <html>
      <head>생략</head>
      <body>
        <frameset>
            <frame name="top" src="~~"/>
            <frame name="sidebar" src="~~"/>
              <frame name="content" src="~~"/>
              <frame name="footer" src="~~"/>
        </frameset>
      </body>
    </html>

frameset 으로 된 페이지의 리로드는 location.reload()로는 가능하지 않다.
각각의 프레임당 location이 다르기 때문.
사실 이 명령도 DOM 구조를 파악하면 쉬운 문제인데, parent.frames.location.reload(); 명령이면 모든 프레임이 리로드 된다.

728x90
반응형

SMTP 오류 코드 및 내용에 관한 표준 설명임.
대략적인 표준은 존재하나, 대부분의 메일 서버들이 표준적인 의미를 준수하지 않음으로 참고만 하고, 해당 메일의 서버 담당자에게 문의 하도록 하자.

SMTP 4XX

메일 교환시에 발생하는 4XX 오류들은 수신 서버의 오류 및 발송 서버의 잘못된 요청 작없 혹은 수신 서버의 스팸정책에 의한 메일 수신 거절, 또는 수신 서버의 일시적인 장애 때문에 발생할 수 있는 일시적인 오류임.

SMTP 421

Service Not Abailable, closing transmission channel.
해당 서버가 정상 작동하지 않기 때문에, 요청한 연결을 거절한다는 내용.

  • 서버가 클라이언트의 접속 자체를 거부하는 경우.
  • 서버가 비정상적인 상황인 경우.
  • 서버에 많은 부하가 있어 일시적으로 접속을 거절한 경우.
  • 서버에서 알 수 없는 오류 발생시.

SMTP 450

Requested action aborted: local error in processing.
수신측 메일 서버의 내부적인 이유로 메일 교환 작업 거절.
대부분 스팸 설정 때문에 거절하는 경우.

  • 제한된 크기보다 메일이 큰 경우.
  • 첨부 파일이 많은 경우.
  • 수신측 서버의 알 수 없는 오류

SMTP 451

Requested action aborted: local error in processing.
수신측 메일 서버의 내부적인 이유로 메일 교환 작업을 거절하는 경우.

  • 수신측 메일 서버의 내부적인 이유노 메일 수신 작업을 거절하는 경우
  • 대부분의 경우는 수신측의 스팸 설정때문에 거절하는 경우
  • 제한된 크기보다 메일이 큰 경우, 첨부 파일가 많은 경우.
  • 수신측 서버의 알수 없는 오류.

SMTP 451

Resources temporarily unavailable. Please try again later.
수신측 메일 서버의 부하로 메일 교환 작업을 일시적으로 거절.

SMTP 452

Requested action not taken: insufficient system storage.
수신측 메일 서버의 내부적인 이유로 메일 교환 작업을 거절.

  • 수신측 메일 서버의 내부적인 이유 때문에, 메일 수신 작업을 거절하는 경우.
  • 수신측의 스팸 설정 때문에 거절하는 경우
  • 한개의 연결에서 너무 많은 RCTP 반복이 수행된 경우
  • 수신측 서버의 알수 없는 오류.
728x90
반응형

'ETC' 카테고리의 다른 글

mixin  (0) 2024.01.10
[PowerShell] 텍스트파일 분리  (0) 2022.03.29
[ETC TIP] Windows 환경에서 Tomcat Log 실시간 보기  (0) 2021.03.15
[조달청/나라장터] iframe 링크 생성  (0) 2021.02.04
대용량 텍스트 파일 읽기  (0) 2020.07.01

+ Recent posts