вторник, 19 августа 2014 г.

C# данные для TreeView из базы данных

private void LoadTree()
{
    DataTable tbl = new DataTable();


    tbl = oraConnector.ExecQuery("select account_id, parent, 
                                  type, name from account");

    //Use a DataSet to manage the data
    DataSet ds = new DataSet();
    ds.Tables.Add(tbl);

    //add a relationship
    ds.Relations.Add("rsParentChild",  
                     ds.Tables[0].Columns["account_id"],  
                     ds.Tables[0].Columns["parent"]);

    foreach (DataRow dr in tbl.Rows)
    {
        if (dr["parent"] == DBNull.Value)
        {
            TreeNode root = new TreeNode(dr["name"].ToString());
            root.Tag = dr["type"].ToString();
            treeView.Nodes.Add(root);
            PopulateTree(dr, root);
        }
    }

    // treeView.ExpandAll();
}

public void PopulateTree(DataRow dr, TreeNode pNode)
{

    foreach (DataRow row in dr.GetChildRows("rsParentChild"))
    {
        TreeNode cChild = new TreeNode(row["NAME"].ToString());
        cChild.Tag = row["TYPE"].ToString();
        pNode.Nodes.Add(cChild);

        //Recursively build the tree
        PopulateTree(row, cChild);
    }
}

понедельник, 18 августа 2014 г.

C# Capturing keyboard activity of another application with the Raw Input API

Источник (source): http://www.news2news.com/vfp/?example=572&ver=vcs&PHPSESSID=3D014ff%3D

using System;
using System.Windows.Forms;
using RawInputHook.DeviceManager;
 
namespace RawInputHook.WinForm
{
    public partial class RawInputMonitorForm : Form
    {
        public RawInputMonitorForm()
        {
            InitializeComponent();
 
            RawInputDeviceManager mgr = new RawInputDeviceManager();
            mgr.RawInputEvent += new RawInputEventHandler(OnRawInputEvent);
 
            mgr.AddKeyboardDevice(this.Handle);
            mgr.RegisterDevices();
 
            Application.AddMessageFilter(mgr);
        }
 
        void OnRawInputEvent(object sender, RawInputEventArgs e)
        {
            if (e.asciiCode != 0)
            {
                switch (e.asciiCode)
                {
                    case 13:
                        textBox1.Text += "\r\n";
                        break;
                    default:
                        textBox1.Text += (char)e.asciiCode;
                        break;
                }
            }
        }
 
    }
}

 
// ======================================
 
using System;
using System.Collections.Generic;
using System.Runtime.InteropServices;
using System.Windows.Forms;
 
namespace RawInputHook.DeviceManager
{
     public delegate void RawInputEventHandler(
        object sender, RawInputEventArgs e);
 
    public class RawInputDeviceManager : IMessageFilter
    {
        const int WM_INPUT = 0x00ff;
        public event RawInputEventHandler RawInputEvent;
        List < RAWINPUTDEVICE > devices = new List < RAWINPUTDEVICE > ();
 
        public void AddKeyboardDevice(IntPtr windowHandle)
        {
            AddDevice(1, 6, 0x100, windowHandle);
        }
 
        void AddDevice(ushort usagePage, ushort usage,
            Int32 flags, IntPtr windowHandle)
        {
            devices.Add(new RAWINPUTDEVICE(usagePage, usage,
                flags, windowHandle));
        }
 
        public bool RegisterDevices()
        {
            if (devices.Count == 0) return false;
 
            RAWINPUTDEVICE[] d = devices.ToArray();
            bool result = RegisterRawInputDevices(d, devices.Count,
                Marshal.SizeOf(typeof(RAWINPUTDEVICE)));
 
            return result;
        }
 
        void ProcessRawInput(IntPtr hRawInput)
        {
            RAWINPUT pData = new RAWINPUT();
            int pcbSize = Marshal.SizeOf(typeof(RAWINPUT));
 
            int result = GetRawInputData(hRawInput,
                RawInputCommand.Input, out pData,
                ref pcbSize, Marshal.SizeOf(typeof(RAWINPUTHEADER)));
 
            if (result != -1)
            {
                if (pData.Header.Type == RawInputType.Keyboard)
                {
                    if ((pData.Keyboard.Flags == 0) || 
                        (pData.Keyboard.Flags == 2))
                    {
                        int asciiCode = VKeyToChar(
                            pData.Keyboard.VirtualKey,
                            pData.Keyboard.MakeCode);
 
                        RawInputEvent(this, 
                            new RawInputEventArgs(pData, asciiCode));
                    }
                }
            }
        }
 
        int VKeyToChar(int virtKey, int scanCode)
        {
            int asciiCode = 0;
            byte[] kbdState = new byte[256];
            GetKeyboardState(kbdState);
            ToAscii(virtKey, scanCode, kbdState, ref asciiCode, 0);
            return asciiCode;
        }
 
        #region IMessageFilter Members
 
        public bool PreFilterMessage(ref Message m)
        {
            if (m.Msg == WM_INPUT)
            {
                if (m.WParam != (IntPtr)0) //the app is on background
                {
                    if (RawInputEvent != null) //event implemented
                    {
                        ProcessRawInput(m.LParam);
                        return true; //stop the message
                    }
                }
            }
            return false; //allow the message to continue
        }
 
        #endregion
 
        [DllImport("user32.dll")]
        static extern bool RegisterRawInputDevices(
            [MarshalAs(UnmanagedType.LPArray, SizeParamIndex = 0)] 
            RAWINPUTDEVICE[] pRawInputDevices,
            int uiNumDevices, int cbSize);
 
        [DllImport("user32.dll")]
        static extern int GetRawInputData(IntPtr hRawInput,
            RawInputCommand uiCommand, out RAWINPUT pData,
            ref int pcbSize, int cbSizeHeader);
 
        [DllImport("user32.dll")]
        static extern int GetKeyboardState(byte[] lpKeyState);
 
        [DllImport("user32.dll")]
        static extern int MapVirtualKey(int uCode, int uMapType);
 
        [DllImport("user32.dll")]
        static extern int ToAscii(int uVirtKey, int uScanCode,
            byte[] lpKeyState, ref int lpChar, int uFlags);
    }
 
    public class RawInputEventArgs : EventArgs
    {
        public RAWINPUT rawInput;
        public int asciiCode = 0;
        public RawInputEventArgs(RAWINPUT rawInput, int asciiCode)
        {
            this.rawInput = rawInput;
            this.asciiCode = asciiCode;
        }
    }
 
    [StructLayout(LayoutKind.Sequential)]
    struct RAWINPUTDEVICE
    {
        public ushort UsagePage;
        public ushort Usage;
        public Int32 Flags;
        public IntPtr WindowHandle;
        public RAWINPUTDEVICE(ushort usagePage, ushort usage,
            Int32 flags, IntPtr windowHandle)
        {
            UsagePage = usagePage;
            Usage = usage;
            Flags = flags;
            WindowHandle = windowHandle;
        }
    }
 
    [StructLayout(LayoutKind.Explicit)]
    public struct RAWINPUT
    {
        [FieldOffset(0)]
        public RAWINPUTHEADER Header;
        [FieldOffset(16)]
        public RAWKEYBOARD Keyboard;
        //mouse and HID parts omitted
    }
 
    [StructLayout(LayoutKind.Sequential)]
    public struct RAWINPUTHEADER
    {
        public RawInputType Type;
        public int Size;
        public IntPtr Device;
        public IntPtr wParam;
    }
 
    [StructLayout(LayoutKind.Sequential)]
    public struct RAWKEYBOARD
    {
        public ushort MakeCode;
        public ushort Flags;
        public ushort Reserved;
        public ushort VirtualKey;
        public int Message;
        public int ExtraInformation;
    }
 
    public enum RawInputType
    {
        Mouse = 0,
        Keyboard = 1,
        HID = 2
    }
 
    enum RawInputCommand
    {
        Input = 0x10000003,
        Header = 0x10000005
    }
}

вторник, 12 августа 2014 г.

C# перетаскивание формы за другой компонент

1. Подключаем пространство имен:

using System.Runtime.InteropServices;

public const int WM_NCLBUTTONDOWN = 0xA1;
public const int HT_CAPTION = 0x2;


2. Импортируем необходимые библиотеки:

[DllImportAttribute("user32.dll")]
public static extern int SendMessage(IntPtr hWnd, int Msg, int wParam, int lParam);
[DllImportAttribute("user32.dll")]
public static extern bool ReleaseCapture();

3. Пишем обработчик на компонент, за который планируем перетаскивать форму:
private void panel1_MouseMove(object sender, MouseEventArgs e)
{
    if (e.Button == MouseButtons.Left)
    {
        ReleaseCapture();
        SendMessage(Handle, WM_NCLBUTTONDOWN, HT_CAPTION, 0);
    }
}

пятница, 8 августа 2014 г.

C# модем и sms

Класс для декодирования sms-сообщения:

using System;
using System.Collections;
using System.Collections.Generic;
using System.Linq;
using System.Text;

namespace ManagmentSerialPort.Framework.SMS
{
    class SMSDecoder

    {

        Hashtable htAbc;

        public SMSDecoder()
        {
            htAbc = new Hashtable();
            htAbc.Add("0410", "А"); htAbc.Add("0411", "Б");
            htAbc.Add("0412", "В"); htAbc.Add("0413", "Г");
            htAbc.Add("0414", "Д"); htAbc.Add("0415", "Е");
            htAbc.Add("00A8", "Ё"); htAbc.Add("0416", "Ж");
            htAbc.Add("0417", "З"); htAbc.Add("0418", "И");
            htAbc.Add("0419", "Й"); htAbc.Add("041A", "К");
            htAbc.Add("041B", "Л"); htAbc.Add("041C", "М"); 
            htAbc.Add("041D", "Н"); htAbc.Add("041E", "О");
            htAbc.Add("041F", "П"); htAbc.Add("0420", "Р"); 
            htAbc.Add("0421", "С"); htAbc.Add("0422", "Т");
            htAbc.Add("0423", "У"); htAbc.Add("0424", "Ф"); 
            htAbc.Add("0425", "Х"); htAbc.Add("0426", "Ц");
            htAbc.Add("0427", "Ч"); htAbc.Add("0428", "Ш"); 
            htAbc.Add("0429", "Щ"); htAbc.Add("042C", "Ь");
            htAbc.Add("042A", "Ъ"); htAbc.Add("042D", "Э"); 
            htAbc.Add("042E", "Ю"); htAbc.Add("042F", "Я");
            htAbc.Add("0430", "а"); htAbc.Add("0431", "б"); 
            htAbc.Add("0432", "в"); htAbc.Add("0433", "г");
            htAbc.Add("0434", "д"); htAbc.Add("0435", "е"); 
            htAbc.Add("00B8", "ё"); htAbc.Add("0436", "ж");
            htAbc.Add("0437", "з"); htAbc.Add("0438", "и"); 
            htAbc.Add("0439", "й"); htAbc.Add("043A", "к");
            htAbc.Add("043B", "л"); htAbc.Add("043C", "м"); 
            htAbc.Add("043D", "н"); htAbc.Add("043E", "о");
            htAbc.Add("043F", "п"); htAbc.Add("0440", "р"); 
            htAbc.Add("0441", "с"); htAbc.Add("0442", "т"); 
            htAbc.Add("0443", "у"); htAbc.Add("0444", "ф"); 
            htAbc.Add("0445", "х"); htAbc.Add("0446", "ц");
            htAbc.Add("0447", "ч"); htAbc.Add("0448", "ш"); 
            htAbc.Add("0449", "щ"); htAbc.Add("044D", "э");
            htAbc.Add("044E", "ю"); htAbc.Add("044F", "я"); 
            htAbc.Add("0041", "A"); htAbc.Add("0042", "B"); 
            htAbc.Add("0043", "C"); htAbc.Add("0044", "D"); 
            htAbc.Add("0045", "E"); htAbc.Add("0046", "F");
            htAbc.Add("0047", "G"); htAbc.Add("0048", "H"); 
            htAbc.Add("0049", "I"); htAbc.Add("004A", "J");
            htAbc.Add("004B", "K"); htAbc.Add("004C", "L"); 
            htAbc.Add("004D", "M"); htAbc.Add("004E", "N");
            htAbc.Add("004F", "O"); htAbc.Add("0050", "P"); 
            htAbc.Add("0051", "Q"); htAbc.Add("0052", "R");
            htAbc.Add("0053", "S"); htAbc.Add("0054", "T"); 
            htAbc.Add("0055", "U"); htAbc.Add("0056", "V");
            htAbc.Add("0057", "W"); htAbc.Add("0058", "X"); 
            htAbc.Add("0059", "Y"); htAbc.Add("005A", "Z");
            htAbc.Add("0061", "a"); htAbc.Add("0062", "b"); 
            htAbc.Add("0063", "c"); htAbc.Add("0064", "d");
            htAbc.Add("0065", "e"); htAbc.Add("0066", "f"); 
            htAbc.Add("0067", "g"); htAbc.Add("0068", "h");
            htAbc.Add("0069", "i"); htAbc.Add("006A", "j"); 
            htAbc.Add("006B", "k"); htAbc.Add("006C", "l");
            htAbc.Add("006D", "m"); htAbc.Add("006E", "n"); 
            htAbc.Add("006F", "o"); htAbc.Add("0070", "p");
            htAbc.Add("0071", "q"); htAbc.Add("0072", "r"); 
            htAbc.Add("0073", "s"); htAbc.Add("0074", "t");
            htAbc.Add("0075", "u"); htAbc.Add("0076", "v"); 
            htAbc.Add("0077", "w"); htAbc.Add("0078", "x");
            htAbc.Add("0079", "y"); htAbc.Add("007A", "z"); 
            htAbc.Add("0030", "0"); htAbc.Add("0031", "1");
            htAbc.Add("0032", "2"); htAbc.Add("0033", "3"); 
            htAbc.Add("0034", "4"); htAbc.Add("0035", "5");
            htAbc.Add("0036", "6"); htAbc.Add("0037", "7"); 
            htAbc.Add("0038", "8"); htAbc.Add("0039", "9");
            htAbc.Add("0027", "'"); htAbc.Add("002D", "-"); 
            htAbc.Add("002A", "*"); htAbc.Add("0020", " ");
            htAbc.Add("003A", ":"); htAbc.Add("003B", ";"); 
            htAbc.Add("0029", ")"); htAbc.Add("0028", "(");
            htAbc.Add("002E", "."); htAbc.Add("002C", ","); 
            htAbc.Add("0021", "!"); htAbc.Add("003D", "=");
            htAbc.Add("005F", "_"); htAbc.Add("044C", "ь"); 
            htAbc.Add("002B", "+");
        }

        public string DecodeMessage(string sMessage)
        {

            string str = "";
            int n = 4;
            List<string> lst = new List<string>();

            for (int i = 0; i < sMessage.Length; i += n)
            {
                lst.Add(sMessage.Substring(i, n));
            }

            foreach (string code in lst) {
                str += GetCharByCode(code);
            }
            return str;
        }

        private string GetCharByCode(string code)
        {

            string retVal = "";
            try
            {
                retVal = htAbc[code].ToString();
            } catch (Exception ex) {
                // System.Windows.Forms.MessageBox.Show("Отсутствует сопоставление для кода " + code);
                return "?";
            }
            return retVal;
        }
    }
}


Использование класса:

    ...
    SMSDecoder smsDecoder;

    smsDecoder = new Framework.SMS.SMSDecoder();

    MessageBox.Show(smsDecoder.DecodeMessage( "041D043E043C04350440002004320430044804350433043E0020043C043E04310438043B044C043D043E0433043E002004420435043B04350444043E043D04300020002B00370039003800390036003800320030003200330039"));
    ....

В выводимом сообщении мы получаем раскодированный текст "Номер вашего мобильного телефона +79896820239" 

Nginx + Let's Crypt

Шаг 1. Установка Certbot # apt-get install python3-acme python3-certbot python3-mock python3-openssl python3-pkg-resources python3-pyparsing...