Microsoft MVP성태의 닷넷 이야기
글쓴 사람
Sungwoo Park (musicbox3 at nate.com)
홈페이지
첨부 파일
 
(연관된 글이 1개 있습니다.)

라즈베리파이 GPIO를 컨트롤 하는 프로그램을 작성했더니 신호에 따라 컨트롤은 잘 되었습니다.
하지만 받은 값을 textBox에 전달하려 하는데 잘 안됩니다.
namespace echo_Server
 {

    /// <summary>
     /// </summary>
     public sealed partial class MainPage : Page
     {
         
         public MainPage()
         {
             
             this.InitializeComponent();
             acho_sever();
             achoclient();
            
         }
         private async void acho_sever()
         {
             try
             {
                 //Create a StreamSocketListener to start listening for TCP connections.
                 Windows.Networking.Sockets.StreamSocketListener socketListener = new Windows.Networking.Sockets.StreamSocketListener();

                //Hook up an event handler to call when connections are received.
                 socketListener.ConnectionReceived += SocketListener_ConnectionReceived;

                //Start listening for incoming TCP connections on the specified port. You can specify any port that's not currently in use.
                 await socketListener.BindServiceNameAsync("1337");
                 
             }
             catch (Exception e)
             {
                 //Handle exception.
                 
             }

        }
         private async void SocketListener_ConnectionReceived(Windows.Networking.Sockets.StreamSocketListener sender,
     Windows.Networking.Sockets.StreamSocketListenerConnectionReceivedEventArgs args)
         {
             //Read line from the remote client.
             Stream inStream = args.Socket.InputStream.AsStreamForRead();
             StreamReader reader = new StreamReader(inStream);
             string request = await reader.ReadLineAsync();
            //try //일단 익셉션처리를 해보았습니다. 익셉션 에러는 안났는데요
            //{
            // textBox.Text = request; //여기도
            //}
            //catch (COMException)
            //{
            // textBox.Text = request; //또 여기에 넣어봐도 텍스트 박스가 반응을 안합니다.
            //}
            //Send the line back to the remote client.
             Stream outStream = args.Socket.OutputStream.AsStreamForWrite();
             StreamWriter writer = new StreamWriter(outStream);
//리턴값으로 돌려서 값을 반환하고 싶지만 void라 할 수 ㅇ없었습니다. 이런저런 시도를 해봤지만 실패했습니다.
어떻게 해서 출력하면 좋을까요?

            await writer.WriteLineAsync(request);
            await writer.FlushAsync();
         }


[연관 글]






[최초 등록일: ]
[최종 수정일: 12/4/2015]


비밀번호

댓글 작성자
 



2015-12-07 12시13분
예외가 발생하지 않았다면 실제로 request에는 빈 문자열이 있을 가능성이 있습니다. 확인해 보셨나요? ReadLineAsync 한번만 호출했으니 가장 처음의 라인을 가져왔다는 것이고 그것이 개행만 포함된 빈 문자열일 수 있습니다. (디버그 모드로 실행해서 request 변수에 들어간 내용을 확인해 보세요.)
정성태
2015-12-07 08시11분
[박성우] 답변 감사합니다. 제가 실제로 이 소스로 GPIO를 제어했습니다.
Stream inStream = args.Socket.InputStream.AsStreamForRead();
            StreamReader reader = new StreamReader(inStream);
            string request = await reader.ReadLineAsync();
            try
            {
                test = request;
            }
            catch (COMException) {}
            // 이 부분을 추가해서 확인해 보았습니다. 클라이언트로 b를 입력해서 보내니까 제가 미리 선언해 놓은 pin번호 LED에 불이 들어왔으며 b를 제외한 다른 문자열을 넣으니까 불이 꺼졌습니다.
            if (request.Equals("b"))
            {
                pin.Write(GpioPinValue.High);
            }
            else
            {
                pin.Write(GpioPinValue.Low);
            }
그 부분에서 빈 문자열이 아닌 것은 확신 할 수 있습니다. 어떻게 할지 모르겠어서 겟터와 셋터를 만들어서도 사용해보려 했는데 뭔가 SocketListener_ConnectionReceived 이 클래스 안에만 들어가면 다른곳에서 선언된 것들은 사용하려 할때마다 예외 상황이 뜨거나 global::System.Diagnostics.Debugger.Break();여기가 노랗게 되네요.
[guest]
2015-12-07 08시23분
[박성우] try {textBox.Text = request;}
catch (COMException){textBox.Text = request;}
일단 request에는 값이 들어오는 것은 확인 되었습니다. 하지만 text박스에 아무런 변화가 없는 것으로 봐서 try catch는 무시 되고 있는 것 같습니다.
[guest]
2015-12-07 02시09분
다음부터는 ^^ 예외가 발생하는 코드는 다음과 같이 해서 메시지를 출력해 보세요.

try
{
} catch (Exception e)
{
  System.Diagnostics.Debug.WriteLine(e.ToString());
}

그럼, Output 창에서 다음과 같은 메시지를 볼 수 있고,

System.Exception: The application called an interface that was marshalled for a different thread. (Exception from HRESULT: 0x8001010E (RPC_E_WRONG_THREAD))
   at Windows.UI.Xaml.Controls.TextBox.put_Text(String value)
   at App1.MainPage.<SocketListener_ConnectionReceived>d__2.MoveNext()

이 메시지를 올려주셨다면 좀더 쉽게 답변을 드릴 수 있었을 것입니다. 답은 다음의 글을 참고하세요. ^^

The application called an interface that was marshalled for a different thread in window 8
; http://stackoverflow.com/questions/11218911/the-application-called-an-interface-that-was-marshalled-for-a-different-thread-i
정성태
2015-12-08 12시35분
예 말씀해주신대로 참고해서 작성해 넣었더니 잘 됩니다. 감사합니다. 앞으로는 예외 메세지를 같이 출력해서 확인해보겠습니다. 정말 감사합니다.
this.Dispatcher.RunAsync(Windows.UI.Core.CoreDispatcherPriority.Normal, () =>
            {
                textBox.Text = request;
            }).AsTask().Wait();
Sungwoo Park

... 46  47  48  49  50  51  52  53  54  [55]  56  57  58  59  60  ...
NoWriterDateCnt.TitleFile(s)
1279(non...6/23/201411567(글쓴이의 요청으로 삭제합니다.) [17]
1278이상식6/19/201412777.net DLL 내 자바스크립트를 수정 또는 재정의 할 수 있을까요? [3]
1277김솔지6/18/201410494silverlight에서 datagrid, listbox질문이여 [2]
1276정우석6/16/201410012쿠키 [1]
1274김솔지6/10/201414494배포 페이지 url을 얻고 싶습니다. [8]
1272이훈모6/7/201410054정말 어려운 상황에 직면했습니다. [1]
1270Jong...6/2/201419514C#과 C++을 이용한 Image 처리. [13]
1269김아영5/29/201410227InitializeComponent 함수 호출 지연 현상 [5]
1268솔솔5/27/20149868smart client [1]
1266김솔지5/22/201411949clickonce 수정에 대해 알고싶습니다. [2]
1265이은아5/22/201415547DataGridView 헤더를 두줄이상으로 하고싶습니다. [1]파일 다운로드1
1264김인호5/18/201413150소스코드 및 예제그림 zip 파일 [1]
1263이영종5/15/201411602159페이지 오타인것 같습니다 [5]
1262(non...5/4/201412465(글쓴이의 요청으로 삭제합니다.) [10]
1261이근주5/4/201410772다시 한번 질문드릴께요. [2]
1259이근주5/1/20149819도서 오류인 것 같네요.. [1]
1258최세정4/28/201412231안녕하세요~php module 오류로 고민하다가 여기까지 왔네요..ㅜㅜ [2]
1252popo4/21/201411479바인딩 질문입니다. [2]
1251(non...4/20/201415599(글쓴이의 요청으로 삭제합니다.) [11]
1249홍용규4/17/201415612app.config 파일 관련 질문 있습니다. [2]
1246(non...3/30/201411940(글쓴이의 요청으로 삭제합니다.) [1]
1245POPO3/26/201411346Http 프로토콜 관련 질문 입니다. [1]
1244(non...3/26/201411453(글쓴이의 요청으로 삭제합니다.) [1]
1241(non...3/22/201415229(글쓴이의 요청으로 삭제합니다.) [4]
1240이석주3/21/201418133인터넷 익스플로러가 hang이 걸리는 현상 문의 [1]파일 다운로드1
1238(non...3/13/201411992(글쓴이의 요청으로 삭제합니다.) [2]
... 46  47  48  49  50  51  52  53  54  [55]  56  57  58  59  60  ...