'C# / ASP.NET'에 해당되는 글 46건

  1. 2013.05.23 C# 윈폼 트레이로 최소화 하기
  2. 2013.05.22 C# 소켓의 포트를 동적으로 변경하기
  3. 2012.10.16 C# 실행시간에 웹서비스 참조 추가하기
  4. 2012.07.06 ASP.NET QueryString 인코딩 설정
  5. 2011.12.13 C# const, readonly, sealed의 차이점
  6. 2011.12.05 C# MDI 자식 폼에서 MDI 부모 폼 접근
  7. 2011.11.23 ASP.NET에서 Log4Net 사용하기
2013.05.23 16:16

C# 윈폼 트레이로 최소화 하기

1. 빈 폼을 만든다.


2. 폼에 NotifyIcon 컨트롤을 추가한다.


3. 폼에 Resize 이벤트 추가


4. Resize 이벤트에 아래 코드 입력

private void Form1_Resize(object sender, EventArgs e)
{
    //notifyIcon1.BalloonTipTitle = "Monimize to Tray App";
    //notifyIcon1.BalloonTipText = "You have successfully minimized you form";

    if (FormWindowState.Minimized == this.WindowState)
    {
        notifyIcon1.Visible = true;
        this.Hide();
    }
    else if (FormWindowState.Normal == this.WindowState)
    {
        notifyIcon1.Visible = false;
        this.ShowInTaskbar = true;
    }
}


5. NotifyIcon에 MouseDoubleClick 이벤트 추가


6. MouseDoubleClick 이벤트에 아래코드 입력

private void notifyIcon1_MouseDoubleClick(object sender, MouseEventArgs e)
{
    this.Show();
    this.WindowState = FormWindowState.Normal;
}


Trackback 0 Comment 0
2013.05.22 18:53

C# 소켓의 포트를 동적으로 변경하기

Socket의 SetSocketOption 메소드를 사용하고 다시 바인드를 시키면 됨

socket.SetSocketOption(SocketOptionLevel.Socket,SocketOptionName.ReuseAddress, true);


[출처] Can't Re-bind a socket to an existing IP/Port Combination

Trackback 0 Comment 0
2012.10.16 11:11

C# 실행시간에 웹서비스 참조 추가하기

웹서비스 참조 생성에 필요한 클래스
using System;
using System.Collections.Generic;
using System.Text;
using System.Reflection;
using System.CodeDom;
using System.CodeDom.Compiler;
using System.Security.Permissions;
using System.Web.Services.Description;

namespace WebServiceCall
{
    internal class WsProxy
    {
        [SecurityPermissionAttribute(SecurityAction.Demand, Unrestricted = true)]

        internal static object CallWebService(string webServiceAsmxUrl, string serviceName, string methodName, object[] args)
        {
            System.Net.WebClient client = new System.Net.WebClient();

            // Connect To the web service
            System.IO.Stream stream = client.OpenRead(webServiceAsmxUrl + "?wsdl");

            // Now read the WSDL file describing a service.
            ServiceDescription description = ServiceDescription.Read(stream);

            ///// LOAD THE DOM /////////
            // Initialize a service description importer.
            ServiceDescriptionImporter importer = new ServiceDescriptionImporter();
            importer.ProtocolName = "Soap12"; // Use SOAP 1.2.
            importer.AddServiceDescription(description, null, null);

            // Generate a proxy client.
            importer.Style = ServiceDescriptionImportStyle.Client;

            // Generate properties to represent primitive values.
            importer.CodeGenerationOptions = System.Xml.Serialization.CodeGenerationOptions.GenerateProperties;

            // Initialize a Code-DOM tree into which we will import the service.
            CodeNamespace nmspace = new CodeNamespace();
            CodeCompileUnit unit1 = new CodeCompileUnit();
            unit1.Namespaces.Add(nmspace);

            // Import the service into the Code-DOM tree. This creates proxy code that uses the service.
            ServiceDescriptionImportWarnings warning = importer.Import(nmspace, unit1);

            if (warning == 0) // If zero then we are good to go
            {

                // Generate the proxy code
                CodeDomProvider provider1 = CodeDomProvider.CreateProvider("CSharp");

                // Compile the assembly proxy with the appropriate references
                string[] assemblyReferences = new string[5] { "System.dll", "System.Web.Services.dll", "System.Web.dll", "System.Xml.dll", "System.Data.dll" };

                CompilerParameters parms = new CompilerParameters(assemblyReferences);

                CompilerResults results = provider1.CompileAssemblyFromDom(parms, unit1);

                // Check For Errors
                if (results.Errors.Count > 0)
                {
                    foreach (CompilerError oops in results.Errors)
                    {
                        System.Diagnostics.Debug.WriteLine("========Compiler error============");
                        System.Diagnostics.Debug.WriteLine(oops.ErrorText);
                    }

                    throw new System.Exception("Compile Error Occured calling webservice. Check Debug ouput window.");
                }

                // Finally, Invoke the web service method
                object wsvcClass = results.CompiledAssembly.CreateInstance(serviceName);

                MethodInfo mi = wsvcClass.GetType().GetMethod(methodName);

                return mi.Invoke(wsvcClass, args);

            }
            else
            {
                return null;
            }
        }
    }
}


웹 서비스 호출

object a = WsProxy.CallWebService("웹서비스 asmx url", "서비스명", "메소드명", new object[]{파라미터들});

[출처] Adding a Web reference dynamically at Runtime


Trackback 0 Comment 0
2012.07.06 13:10

ASP.NET QueryString 인코딩 설정

프로젝트내 전체 페이지 설정

web.config 파일내 다음 문구 삽입

<configuration>
  <system.web>
    <globalization
      fileEncoding="utf-8"
      requestEncoding="utf-8"
      responseEncoding="utf-8"
      culture="en-US"
      uiCulture="de-DE"
    />
  </system.web>
</configuration>


페이지별 설정

페이지에 아래문구 삽입

<%@ Page RequestEncoding="utf-8" ResponseEncoding="utf-8" %>


한글 인코딩시 utf-8이 아니라 euc-kr로 설정해야 함


[출처] How to: Select an Encoding for ASP.NET Web Page Globalization

Trackback 0 Comment 0
2011.12.13 16:10

C# const, readonly, sealed의 차이점

sealed
class modifier
클래스를 더이상 상속할수 없게 만들고 싶은때 사용
[attributes] sealed class identifier [class-base] class-body  [;]

const
필드나 로컬 변수의 선언을 변경하는데 사용한다.
const 로 선언된 필드나 로컬 변수는 변경될 수 없음을 지정한다.
[attributes] [modifiers] const type declarators;

readonly
const 와 역활은 같지만 초기화방법이 조금 차이가 있다.
선언과 동시에 초기화 할 수도 있고 생성자등에서 초기화가 가능한다.
즉 const는 compile time의 constant이고 readonly는 runtime에 constant로 사용될 수 있다.


[출처] const, readonly, sealed의 차이점
Trackback 0 Comment 0
2011.12.05 15:33

C# MDI 자식 폼에서 MDI 부모 폼 접근

MDI를 사용하다 보면 자식 폼에서 부모 MDI에 접근이 필요한 경우가 있다.
C#에서는 MdiParanet라는 변수를 제공하는 이는 폼의 MDI 부모의 레퍼런스이다.

사용 방법은
MDI 부모폼의 이름이 MDIMain이라고 가정했을때

MDIMain parent = (MDIMain)this.MdiParent;
parent.SomeMethod();


[참고] How to Access MDI Parent Forms From MDI Child Form
Trackback 0 Comment 0
2011.11.23 16:39

ASP.NET에서 Log4Net 사용하기

log4net은 응용프로그램에서와 같이 ASP.NET 웹서비스에서도 로그를 남기기 위해 사용될 수 있다.log4net은 응용프로그램에서와 같이 ASP.NET 웹서비스에서도 다음의 2가지 작업만 하면 로그를 남길 수 있다.

1. Global.asax에서 로깅 환경 설정을 초기화 하는 코드 추가
2. Web.config에서 log4net 관련 설정 추가

ASP.NET 웹서비스에서는 반드시 Global.asax파일을 정의해야 하는데, 직접 asax에 또는 코드비하인드 파일에 초기화 코드가 추가되어져야 한다.

다음의 코드가 가장 일반적으로 로그 초기화에 사용되는 Global.asax파일 내용이다.

<%@ Application Language="C#" %>
<script runat="server">
private void Application_Start(Object sender, EventArgs e)
{
     log4net.Config.DOMConfigurator.Configure();
}
</script>

만약 Global.asax의 코드비하인드 파일을 사용할 거라면 Global.asax는 간단하게 다음과 같이 정의 하면되고
<%@ Application Codebehind="Global.asax.cs" Inherits="MyApp.Global" %>

다음과 같은 코드를 Global.asax.cs파일에 추가하면 된다.

namespace MyApp
{
  public class Global : System.Web.HttpApplication
  {
    /// 
    /// Called when the web application starts
    /// 
    /// who
    /// what
    protected void Application_Start(Object sender, EventArgs e)
    {
      // 응용프로그램이 로딩 될 때 로그를 초기화 함.
      log4net.Config.DOMConfigurator.Configure();
    }

  }
}



웹서비스가 로드(또는 리로드 - load or reload) 될 때 Application_Start 메쏘드가 자동으로 호출된다. 보는 바와 같이 이때 log4net환경의 초기화를 이때 수행한다.

각각의 웹서비스들이 자체 폴더(버추얼 디렉토리)를 가지고 있고 각 폴더에는 웹서비스의 설정을 위해 Web.config 파일들을 하나씩 가지고 있게 되는데 이 파일에 log4net을 위한 설정을 추가하게 된다.

log4net의 설정값을 가지고 있는 Web.config 파일의 예는 다음과 같다.



  
    


[출처] ASP.NET 에서 Log4Net 사용하기
Trackback 0 Comment 0