U E D R , A S I H C RSS

Ruby/2011년스터디/서지혜

Difference between r1.2 and the current

@@ -1,2 +1,127 @@
[[pagelist(^Ruby/2011년스터디)]]
[[TableOfContents]]
== 프로젝트 ==
* 일정 시간이 지나면 웹 브라우저를 종료하는 프로그램 만들기
* 0207 : 프로그램 명세. 엔포지에 프로젝트 생성([http://nforge.zeropage.org/projects/deletewastes 엔포지 링크])
 
== 프로그램 기능 ==
* OS에게 현재 실행중인 웹 브라우저의 정보(총 실행 시간, 현재 뷰중인 페이지)를 얻어 일정시간이상 실행된 (틍정 사이트를 뷰 중인) 웹 브라우저 종료시키기
 
== 실행 순서 ==
* OS에게 웹 브라우저의 정보 얻음
* 일정시간 이상 실행된 웹 브라우저 검색 (혹은 직접 카운트)
* 특정 사이트를 뷰중인지 검색
* 해당 브라우저에게 종료 메세지 보냄 (혹은 경고창을 띄움)
 
== 예상 예외사항 ==
* 웹 브라우저의 정보를 얻을 수 없을 때
* 실행중인 웹 브라우저가 없을 때
* 프로세서간 통신 실패시
* 웹 브라우저가 종료되지 않을 때
* 잘못된 웹 브라우저의 종료
 
== 제약사항 ==
* 프로세스간의 통신
* 루비에서의 윈도우API사용
 
== 예상 문제점 ==
* 루비와 윈도우API의 호환성
* 윈도우API 사용법 습득
 
== 추가 기술 사항 ==
* OS 부팅 시 자동 실행
* 웹 브라우저의 페이지 뷰를 기록하여 통계
* 멀티 탭 브라우저일 때 탭만 종료하기
 
== 배운것 ==
=== 2월 21일 ===
* 윈도우 API 테스트
* windows API로 프로세스의 정보 받아오기 ([http://sosal.tistory.com/100 원본])
{{{
~cpp
#include <stdio.h>
#include <stdlib.h>
#include <tchar.h>
#include <Windows.h>
#include <TlHelp32.h>
 
void killProcess(TCHAR*);
 
int _tmain(int argc, TCHAR *argv[]){
// snap every current process
HANDLE hProcessSnap = CreateToolhelp32Snapshot(TH32CS_SNAPPROCESS, 0);
 
if(hProcessSnap == INVALID_HANDLE_VALUE) {
_tprintf(_T("CreateToolhelp32Snapshot erre\n"));
exit(EXIT_FAILURE);
}
 
// structure to hold process's inform
PROCESSENTRY32 pe32;
pe32.dwSize = sizeof(PROCESSENTRY32);
 
// Process32First :: get the first process snapshot
if(!Process32First(hProcessSnap, &pe32)){
_tprintf(_T("Process32First error!\n"));
CloseHandle(hProcessSnap);
exit(EXIT_FAILURE);
}
 
_tprintf(_T("\t[Process name]\t[PID]\t[ThreadID]\t[PPID]\n"));
int countProcess=0;
do{
countProcess += 1;
_tprintf(_T("%25s %8d %8d %8d\n"),
pe32.szExeFile, pe32.th32ProcessID, pe32.cntThreads, pe32.th32ParentProcessID);
}while(Process32Next(hProcessSnap, &pe32));
printf("number of process = %d", countProcess);
 
return 0;
}
}}}
* 특정 프로세스 죽이기 ([http://sosal.tistory.com/entry/%ED%94%84%EB%A1%9C%EC%84%B8%EC%8A%A4-%EB%A6%AC%EC%8A%A4%ED%8A%B8-%EC%B6%9C%EB%A0%A5-%EA%B0%95%EC%A0%9C-%EC%A2%85%EB%A3%8C-%EC%86%8C%EC%8A%A4 원본])
{{{
~cpp
#include <stdio.h>
#include <stdlib.h>
#include <tchar.h>
#include <Windows.h>
#include <TlHelp32.h>
 
void killProcess(TCHAR*);
 
int _tmain(int argc, TCHAR *argv[]){
// kill process
TCHAR *targetProcess = _T("NateOnMain.exe"); // 종료하려는 프로세스의 이름을 쓴다
killProcess(targetProcess);
return 0;
}
 
// Works fine
void killProcess(TCHAR *target){
HANDLE hProcessSnap = CreateToolhelp32Snapshot(TH32CS_SNAPPROCESS, 0);
PROCESSENTRY32 pe32;
pe32.dwSize = sizeof(PROCESSENTRY32);
 
 
HANDLE hProcess = NULL;
do{
if(0 == _tcscmp(pe32.szExeFile, target)){
// get the process handle
hProcess = OpenProcess(PROCESS_ALL_ACCESS, FALSE, pe32.th32ProcessID);
 
if(hProcess){
// kill it
TerminateProcess(hProcess, -1);
CloseHandle(hProcess);
printf("종료 성공!");
break;
}
}
}while(Process32Next(hProcessSnap, &pe32));
 
CloseHandle(hProcessSnap);
}
 
}}}




1. 프로젝트

  • 일정 시간이 지나면 웹 브라우저를 종료하는 프로그램 만들기
  • 0207 : 프로그램 명세. 엔포지에 프로젝트 생성(엔포지 링크)

2. 프로그램 기능

  • OS에게 현재 실행중인 웹 브라우저의 정보(총 실행 시간, 현재 뷰중인 페이지)를 얻어 일정시간이상 실행된 (틍정 사이트를 뷰 중인) 웹 브라우저 종료시키기

3. 실행 순서

  • OS에게 웹 브라우저의 정보 얻음
  • 일정시간 이상 실행된 웹 브라우저 검색 (혹은 직접 카운트)
  • 특정 사이트를 뷰중인지 검색
  • 해당 브라우저에게 종료 메세지 보냄 (혹은 경고창을 띄움)

4. 예상 예외사항

  • 웹 브라우저의 정보를 얻을 수 없을 때
    • 실행중인 웹 브라우저가 없을 때
    • 프로세서간 통신 실패시
  • 웹 브라우저가 종료되지 않을 때
    • 잘못된 웹 브라우저의 종료

5. 제약사항

  • 프로세스간의 통신
    • 루비에서의 윈도우API사용

6. 예상 문제점

  • 루비와 윈도우API의 호환성
  • 윈도우API 사용법 습득

7. 추가 기술 사항

  • OS 부팅 시 자동 실행
  • 웹 브라우저의 페이지 뷰를 기록하여 통계
  • 멀티 탭 브라우저일 때 탭만 종료하기

8. 배운것

8.1. 2월 21일

  • 윈도우 API 테스트
    • windows API로 프로세스의 정보 받아오기 (원본)

~cpp
#include <stdio.h>
#include <stdlib.h>
#include <tchar.h>
#include <Windows.h>
#include <TlHelp32.h>

void killProcess(TCHAR*);

int _tmain(int argc, TCHAR *argv[]){
	// snap every current process 
	HANDLE hProcessSnap = CreateToolhelp32Snapshot(TH32CS_SNAPPROCESS, 0);

	if(hProcessSnap == INVALID_HANDLE_VALUE) {
		_tprintf(_T("CreateToolhelp32Snapshot erre\n"));
		exit(EXIT_FAILURE);
	}

	// structure to hold process's inform
	PROCESSENTRY32 pe32;
	pe32.dwSize = sizeof(PROCESSENTRY32);

	// Process32First :: get the first process snapshot
	if(!Process32First(hProcessSnap, &pe32)){
		_tprintf(_T("Process32First error!\n"));
		CloseHandle(hProcessSnap);
		exit(EXIT_FAILURE);
	}

	_tprintf(_T("\t[Process name]\t[PID]\t[ThreadID]\t[PPID]\n"));
	int countProcess=0;
	do{
		countProcess += 1;
		_tprintf(_T("%25s %8d %8d %8d\n"), 
			pe32.szExeFile, pe32.th32ProcessID, pe32.cntThreads, pe32.th32ParentProcessID);
	}while(Process32Next(hProcessSnap, &pe32));
	printf("number of process = %d", countProcess);

	return 0;
}
  • 특정 프로세스 죽이기 (원본)

~cpp
#include <stdio.h>
#include <stdlib.h>
#include <tchar.h>
#include <Windows.h>
#include <TlHelp32.h>

void killProcess(TCHAR*);

int _tmain(int argc, TCHAR *argv[]){
	// kill process
	TCHAR *targetProcess = _T("NateOnMain.exe"); // 종료하려는 프로세스의 이름을 쓴다
	killProcess(targetProcess);
	return 0;
}

// Works fine
void killProcess(TCHAR *target){
	HANDLE hProcessSnap = CreateToolhelp32Snapshot(TH32CS_SNAPPROCESS, 0);
	PROCESSENTRY32 pe32;
	pe32.dwSize = sizeof(PROCESSENTRY32);


	HANDLE hProcess = NULL;
	do{
		if(0 == _tcscmp(pe32.szExeFile, target)){
			// get the process handle
			hProcess = OpenProcess(PROCESS_ALL_ACCESS, FALSE, pe32.th32ProcessID);

			if(hProcess){
				// kill it
				TerminateProcess(hProcess, -1);
				CloseHandle(hProcess);
				printf("종료 성공!");
				break;
			}
		}
	}while(Process32Next(hProcessSnap, &pe32));

	CloseHandle(hProcessSnap);
}

Valid XHTML 1.0! Valid CSS! powered by MoniWiki
last modified 2021-02-07 05:27:56
Processing time 0.0340 sec