안녕하세요`
웹페이지 이벤트시 웹서버단 파일[ㅁㅁㅁ.exe]을 로컬의 특정 경로에 가저와서 저장하고 다시 실행[Proecss.Start()]하려합니다.
간단히 ActiveX만들어서 배포시에 ㅁㅁㅁ.exe 파일을 캡파일에 첨부하여 로컬로내려보내고 실행을 하였습니다.]
Activex를 사용하여 로컬에 파일을 다운로드 하고 실행하고 하는 방법이외에 다른방법이 없나,... 하여 이리저리 시도해보는 중에
혹시 먼저 이런 고민을 해보신 선배님들이 계시면 충고를좀 주십사 하여 이렇게 몇자 적어봄니다.
--Test.aspx.cs --
1: --아래코드도 로컬iis 이외에 개발서버등 원격서버에선 aaa.txt.가 권한문제로 아니된단 말씀이죠...[여기서 아래 4번 가장코드를 좀...해보았습니다...]
--컴파일하고 실행하여 원격서버에 파일 받아오는건 윈도통합인증으로 아무 문제가 없더란~말씀--
--서버단으로 올라가는 즉시~권한이 없나~--
string strFileName = "http://devportal:8080/SycEP/Portlet/ERP/OCX/aaa.txt";
WebClient myClient = new WebClient();
Uri Path = new Uri(strFileName);
myClient.DownloadFile(strFileName, @"C:\aaa.txt");
2:
--로컬에서 원격서버 다녀온후--
--다운받은파일을 웹에서 바로 실행합니다[이런 무식한!! 하고 말씀주셔도 됩니다 ㅠ.ㅜ 요고 실행땜시 ActiveX가 필요한....]
Thread.Sleep(2000);
string strGains_Root=@"C:\aaa.txt";
System.Diagnostics.Process TestProcess =new System.Diagnostics.Process();
TestProcess.StartInfo.FileName=strGains_Root;
TestProcess.StartInfo.UseShellExecute=false;
TestProcess.Start();
--작업관리자엔 notepade.exe가 올라와 있습니다 -- ㅡ.,ㅡ 물론 프로세스 주인이 ASP.NET이라는...
--ASP.NET이 운영체제의 일부로 기능하게 하여도 동일하게 작업관리자엔 올라오지만 실행은 안되있다는거`
===작업관리자===
[1] notepade.exe ASP.net ....[이아이는 운영체제 일부로 활동 권한을줘도 아래놈같이 실행은 안된다는,,,]
[2] notepade.exe 컴터주인 ....[os의 모든 실행파일은 통합인증만 허용...하는...]
=============
[1]번으로 실행된 프로세스를 [2]번과 같이 하는 방법이 없나...요고시 오늘의 메인 질문입니다.
코드상에 가장이라는걸 좀 찌끄려 봤는데 여전히 원하는건 아니되더라구요,,, 코드는 아래와 같습니다.쩝 ...
string userName = string.Empty;
string password = string.Empty;
string domain = string.Empty;
try
{
domain ="130.1.2.1132";//"130.13.5.2329";//"1303.1.2.1132";//"portalyci"; [테스트의 흔적이....ㅡㅡ]
userName ="administrator"; <---admin 그룹에 사용자도 다 튕겨 내는군요 ㅡㅡ 온니 이놈만 pass시키더라구요
password ="!12syds";
// Call LogonUser to obtain a handle to an access token.
bool returnValue = Win32.LogonUser( userName, domain, password,
Win32.LOGON32_LOGON_INTERACTIVE, Win32.LOGON32_PROVIDER_DEFAULT,
ref tokenHandle);
if (false == returnValue)
{
int ret = Marshal.GetLastWin32Error();
int errorCode = 0x5; //ERROR_ACCESS_DENIED
throw new System.ComponentModel.Win32Exception(errorCode);
}
// Check the identity.
bool retVal = Win32.DuplicateToken(tokenHandle, Win32.SecurityImpersonation, ref dupeTokenHandle);
if (false == retVal)
{
Win32.CloseHandle(tokenHandle);
throw new ApplicationException( "Exception thrown in trying to duplicate token." );
}
// The token that is passed to the following constructor must
// be a primary token in order to use it for impersonation.
WindowsIdentity newId = new WindowsIdentity(dupeTokenHandle);
impersonatedUser = newId.Impersonate();
//throw new Exception(newId.Name + " user : ");
impersonatedUser <---얻어낸 이놈으로 무엇을 해야 할까요...흠...
newId.Name <--가장이 잘되어서 넘어옴니다`쿠오오...[]
제일 첫번째 두번째의 1,2 번코드를 여기다 집어넣었는데 반응이 없군요....
막다른길에 몰려서 이렇게 글을 올리고 있습니다 ...
뭐 쓸때없는짖 한다고 꾸중 주셔도 좋고 방법이 있으면 제시를 부탁드리겠습니다 흑흑 ...
}
catch(Exception ex)
{
throw new Exception(ex.Message + " user : " + userName + " pwd : " + password + " DomainIP : " + domain);
}
뭐 이놈만 순조로히 된다면야[ㅡ.,ㅡ] 머 Activex필요없이 웹서버서 파일 받아서 로컬딴에 저장하고 적절한 권한으로 실행권한 바꿔서 실행[응용프로그램]하면` 편하지 않을까,,,, 하여
엠에스에서 그렇~~~~~~~~~~~게 강조하는 보안보안보안 을 위배하는 짖이라 생각되 되지만 쿠오오 ㅡㅡ 암튼` 선배들께서는 어떻게 생각 하십니까`
즐건주말~야근모드~
[최초 등록일: ]
[최종 수정일: 11/25/2006]