프로젝트

일반

사용자정보

통계
| 개정판:

hytos / DTI_PID / ID2PSN / Program.cs @ abc4250b

이력 | 보기 | 이력해설 | 다운로드 (4.25 KB)

1 7b5ddbe5 humkyung
using Newtonsoft.Json;
2
using System;
3 0dae5645 gaqhf
using System.Collections.Generic;
4 31d37d58 LJIYEON
using System.Data;
5 6b9e7a56 gaqhf
using System.IO;
6 0dae5645 gaqhf
using System.Linq;
7 7b5ddbe5 humkyung
using System.Net.Sockets;
8
using System.Text;
9 0dae5645 gaqhf
using System.Threading.Tasks;
10
using System.Windows.Forms;
11
12
namespace ID2PSN
13
{
14
    static class Program
15
    {
16
        /// <summary>
17
        /// 해당 애플리케이션의 주 진입점입니다.
18
        /// </summary>
19
        [STAThread]
20 6b9e7a56 gaqhf
        static void Main(string[] args)
21 0dae5645 gaqhf
        {
22 14ab89ec esham21
            if (!SingleInstance.Start("ecf2ed2e-1a3f-4926-a561-512857785805"))
23 eb41cac4 esham21
            {
24
                return;
25
            }
26
27 721b754d gaqhf
            ID2Info info = ID2Info.GetInstance();
28 31d37d58 LJIYEON
            DataTable projectTable = null;
29 abee404a LJIYEON
            try
30 673075e0 LJIYEON
            {
31 7b5ddbe5 humkyung
                using (TcpClient tcpClient = new TcpClient())
32 abee404a LJIYEON
                {
33 7b5ddbe5 humkyung
                    tcpClient.SendTimeout = 500;
34
                    tcpClient.Connect("localhost", 2549);
35
36
                    var _params = new Dictionary<string, string>()
37 757ab2f2 LJIYEON
                    {
38 c4a35107 humkyung
                        {"request", "prjinfo" },
39 7b5ddbe5 humkyung
                    };
40
                    var json = JsonConvert.SerializeObject(_params, Formatting.Indented);
41
                    byte[] message = Encoding.UTF8.GetBytes(json);
42 757ab2f2 LJIYEON
43 7b5ddbe5 humkyung
                    using (NetworkStream networkStream = tcpClient.GetStream())
44 757ab2f2 LJIYEON
                    {
45 d4b1ab29 LJIYEON
                        try
46
                        {
47
                            networkStream.Write(message, 0, message.Length);
48 7b5ddbe5 humkyung
49 d4b1ab29 LJIYEON
                            byte[] outbuf = new byte[1024];
50
                            int nbytes = networkStream.Read(outbuf, 0, outbuf.Length);
51
                            string output = Encoding.UTF8.GetString(outbuf, 4, nbytes - 5);
52
                            var result = JsonConvert.DeserializeObject<Dictionary<string, string>>(output);
53 2c46461b LJIYEON
54 d4b1ab29 LJIYEON
                            if (result["db_type"] == "SQLite")
55
                            {
56
                                info.ID2DBType = ID2DB_Type.SQLite;
57
                                var parent = Directory.GetParent(Path.GetDirectoryName(result["db_name"]));
58
                                info.DefaultPath = parent.ToString();
59
                                ///DataRow dr = projectTable.Select(string.Format("DBTypes_UID = 2 AND Name = '{0}'", result["db_name"])).FirstOrDefault();
60
                                ///info.DefaultPath = dr.Field<string>("Path");
61
                            }
62
                            else if (result["db_type"] == "MSSQL")
63
                            {
64
                                info.ID2DBType = ID2DB_Type.MSSQL;
65
                                info.ServerIP = result["host"];
66
                                //info.Port = "3389"; 
67
                                info.DBUser = result["user"];
68
                                info.DBPassword = result["password"];
69
                                info.Database = result["db_name"];
70
                                info.DefaultPath = result["path"];
71
                                ///DataRow dr = projectTable.Select(string.Format("DBTypes_UID = 2 AND Name = '{0}'", result["db_name"])).FirstOrDefault();
72
                                ///info.DefaultPath = dr.Field<string>("Path");
73
                                ///
74 2c46461b LJIYEON
75 d4b1ab29 LJIYEON
                            }
76
77 3f898125 LJIYEON
                            MessageBox.Show(info.ID2DBType + "\n" + info.ServerIP + "\n" + info.DBUser + "\n" + info.DBPassword + "\n" + info.Database + "\n" + info.DefaultPath, "ID2PSN", MessageBoxButtons.OK, MessageBoxIcon.Information);
78 7b5ddbe5 humkyung
                        }
79 d4b1ab29 LJIYEON
                        catch(Exception ex)
80 7b5ddbe5 humkyung
                        {
81 d4b1ab29 LJIYEON
                            MessageBox.Show(ex.StackTrace, "ID2PSN", MessageBoxButtons.OK, MessageBoxIcon.Error);
82 7b5ddbe5 humkyung
                        }
83 757ab2f2 LJIYEON
                    }
84 7b5ddbe5 humkyung
                    tcpClient.Close();
85 abee404a LJIYEON
                }
86 7bc1e1db gaqhf
87 abee404a LJIYEON
                if (DB.ConnTestAndCreateTable())
88
                {
89
                    Application.EnableVisualStyles();
90
                    Application.SetCompatibleTextRenderingDefault(false);
91 7b5ddbe5 humkyung
                    Application.Run(new MainForm());
92 abee404a LJIYEON
                }
93
                else
94
                    MessageBox.Show("fail");
95
            }
96 7b5ddbe5 humkyung
            catch (Exception ex)
97 6b9e7a56 gaqhf
            {
98 d4b1ab29 LJIYEON
                MessageBox.Show(ex.StackTrace, "ID2PSN", MessageBoxButtons.OK, MessageBoxIcon.Error);
99 6b9e7a56 gaqhf
            }
100 0dae5645 gaqhf
        }
101
    }
102
}
클립보드 이미지 추가 (최대 크기: 500 MB)