Changes for page 01 Lua Functions
Last modified by Theodore Xu on 2023/10/26 10:51
Summary
-
Page properties (3 modified, 0 added, 0 removed)
Details
- Page properties
-
- Parent
-
... ... @@ -1,1 +1,1 @@ 1 -V-BOX.V-Net. 1\.UserManual.04 Lua Script.WebHome1 +V-BOX.V-Net.Manual.04 Lua Script.WebHome - Author
-
... ... @@ -1,1 +1,1 @@ 1 -XWiki. Stone1 +XWiki.Hunter - Content
-
... ... @@ -140,7 +140,7 @@ 140 140 141 141 Table 2-1 142 142 143 -(% class="box errormessage" %)143 +(% class="box infomessage" %) 144 144 ((( 145 145 **✎Note: **If HLword enters any other value, it will be treated as invalid. 146 146 ))) ... ... @@ -608,11 +608,12 @@ 608 608 Attempting to use a script to open a serial port in an unsupported mode will result in an error directly, as below. 609 609 610 610 |((( 611 +{{code language="LUA"}} 611 611 local setup = { 612 612 613 613 name = "COM2", 614 614 615 -mode = 422, ~-~- COM2 does not support RS422616 +mode = 422, -- COM2 does not support RS422 616 616 617 617 ... 618 618 ... ... @@ -619,6 +619,7 @@ 619 619 } 620 620 621 621 serial.open(setup) 623 +{{/code}} 622 622 ))) 623 623 624 624 **Data bit:** ... ... @@ -1063,8 +1063,9 @@ 1063 1063 1064 1064 If there is no custom configuration, return an empty table, otherwise, return with "field name/field content" 1065 1065 1066 - E.g:1068 +**For example:** 1067 1067 1070 +{{code language="LUA"}} 1068 1068 { 1069 1069 1070 1070 [1]= {[1]=1234, [2]=1, [3]='temp', [4]='23.5', [5]={"fruit"="apple"}}, ... ... @@ -1077,7 +1077,8 @@ 1077 1077 1078 1078 } 1079 1079 1080 -Failed: //table// empty table 1083 +Failed: table empty table 1084 +{{/code}} 1081 1081 1082 1082 ((( 1083 1083 == **bns_get_config(string from)** == ... ... @@ -1157,13 +1157,15 @@ 1157 1157 1158 1158 Type (1: switch, 2: number, 3: string) 1159 1159 1160 -E.g: 1161 - { 1164 +**For example:** 1162 1162 1163 -[1]={~-~-The first communication port 1166 +{{code language="LUA"}} 1167 +{ 1164 1164 1165 -[1]={ ~-~-monitoring point array of the first communication port1169 +[1]={--The first communication port 1166 1166 1171 +[1]={--monitoring point array of the first communication port 1172 + 1167 1167 [1]={[1]=11,[2]='data1',[3]=3,[4]=2}, 1168 1168 1169 1169 [2]={[1]=12,[2]='data2',[3]=3,[4]=2}, ... ... @@ -1170,23 +1170,23 @@ 1170 1170 1171 1171 ... 1172 1172 1173 -[n]={[1]=xx,[2]='datan',[3]=x,[4]=x}, ~-~-n monitoring points1179 +[n]={[1]=xx,[2]='datan',[3]=x,[4]=x},--n monitoring points 1174 1174 1175 1175 }, 1176 1176 1177 -[2]=14, ~-~-ID1183 +[2]=14, --ID 1178 1178 1179 -[3]='Modbus TCP' ~-~-n monitoring points1185 +[3]='Modbus TCP' --n monitoring points 1180 1180 1181 1181 }, 1182 1182 1183 -[2]={ ~-~-The second communication port1189 +[2]={--The second communication port 1184 1184 1185 -[1]={}, ~-~-The monitoring point of the second communication port is not configured and is empty1191 +[1]={},--The monitoring point of the second communication port is not configured and is empty 1186 1186 1187 -[2]=15, ~-~-ID1193 +[2]=15, --ID 1188 1188 1189 -[3]='WECON' ~-~-communication protocol name1195 +[3]='WECON' --communication protocol name 1190 1190 1191 1191 }, 1192 1192 ... ... @@ -1193,6 +1193,7 @@ 1193 1193 ...n communication ports and so on 1194 1194 1195 1195 } 1202 +{{/code}} 1196 1196 1197 1197 Failed~:// table// empty table 1198 1198 ... ... @@ -1272,8 +1272,9 @@ 1272 1272 1273 1273 Succeed: //table// one-dimensional array 1274 1274 1275 - E.g:1282 +**For example:** 1276 1276 1284 +{{code language="LUA"}} 1277 1277 { 1278 1278 1279 1279 [1]="This is the oldest message", - the first is the oldest message ... ... @@ -1285,6 +1285,7 @@ 1285 1285 [n]="This is the latest message", - the last is the latest message 1286 1286 1287 1287 } 1296 +{{/code}} 1288 1288 1289 1289 Failede: nil 1290 1290 ... ... @@ -1302,7 +1302,7 @@ 1302 1302 1303 1303 == **https request** == 1304 1304 1305 - Example:1314 +**For example:** 1306 1306 1307 1307 {{code language="LUA"}} 1308 1308 local json = require("json") ... ... @@ -1358,7 +1358,7 @@ 1358 1358 1359 1359 **Access in bit mode, the prefix is @B_HDX, the number in front of "." indicates the number of the word, and the number behind is the bit number of the word.** 1360 1360 1361 -For example: @B_HDX1020.12, its meaning is to access the system data area in bit mode, the specific location is the 13th bit of the 1020th word. 1370 +**For example:** @B_HDX1020.12, its meaning is to access the system data area in bit mode, the specific location is the 13th bit of the 1020th word. 1362 1362 1363 1363 (% class="box infomessage" %) 1364 1364 ((( ... ... @@ -1380,7 +1380,7 @@ 1380 1380 1. Access in bit mode, the number range is: "@B_HDX0.0"-"@B_HDX299999.15". 1381 1381 1382 1382 ((( 1383 -== ** 8.2Special data area (HSW/HSX)** ==1392 +== **Special data area (HSW/HSX)** == 1384 1384 1385 1385 (% class="box infomessage" %) 1386 1386 ((( ... ... @@ -1498,8 +1498,19 @@ 1498 1498 ** addr_getstring("@W_HSW191",17) 1499 1499 * Obtaining ICCID (read only) 1500 1500 ** addr_getstring("@W_HSW225",15) 1510 +* ((( 1511 +TSAP settings of Siemens LOGO PLC* 1501 1501 1502 1502 ((( 1514 +addr_setword("@W_0#HSW1200",8192) means set the Local TSAP as 20.00 1515 +))) 1516 + 1517 +* ((( 1518 +addr_setword("@W_0#HSW1201",4096) means set the Remote TSAP as 10.00 1519 +))) 1520 +))) 1521 + 1522 +((( 1503 1503 == **Power-down storage area (HAW/HAX)** == 1504 1504 1505 1505 The system storage area (HAW) is used for the system power-down hold registers: ... ... @@ -1534,7 +1534,7 @@ 1534 1534 Failed: multi 1535 1535 1536 1536 ((( 1537 -== ** 9.2send_sms_ucs2(string number, string message)** ==1557 +== **send_sms_ucs2(string number, string message)** == 1538 1538 ))) 1539 1539 1540 1540 **Function:** ... ... @@ -1683,7 +1683,7 @@ 1683 1683 * number [prarm.refin]: whether each byte of the data to be measured is inverted by bit, true or false. 1684 1684 * number [prarm.refout]: after the calculation or before the heterodyning output, whether the whole data is inverted by bit, true or false. 1685 1685 1686 -Return: 1706 +**Return:** 1687 1687 1688 1688 Success: crc object 1689 1689 ... ... @@ -1742,7 +1742,7 @@ 1742 1742 Failed: multi, error code 1743 1743 ))) 1744 1744 1745 - Example:1765 +**For example:** 1746 1746 1747 1747 {{code language="LUA"}} 1748 1748 function crcTest.main() ... ... @@ -1781,7 +1781,7 @@ 1781 1781 end 1782 1782 {{/code}} 1783 1783 1784 -= **1 1Special function for V-NET** =1804 += **10 Special function for V-NET** = 1785 1785 1786 1786 == **normal_get_alldata()** == 1787 1787 ... ... @@ -1804,8 +1804,9 @@ 1804 1804 ** 2: timeout 1805 1805 * Customization returns an empty table if there is no configuration, otherwise returns "field name/field content" 1806 1806 1807 -For example: 1827 +**For example:** 1808 1808 1829 +{{code language="LUA"}} 1809 1809 { 1810 1810 1811 1811 [1]= {[1]=1234, [2]=1, [3]='temp', [4]='23.5'}, ... ... @@ -1819,6 +1819,7 @@ 1819 1819 } 1820 1820 1821 1821 Failed: table, empty table 1843 +{{/code}} 1822 1822 1823 1823 == **normal_setdata_byname(string name, string data)** == 1824 1824 ... ... @@ -1826,10 +1826,284 @@ 1826 1826 1827 1827 **Parameter:** 1828 1828 1829 -name: the name of mo 1851 +name: the name of monitoring point 1830 1830 1853 +data: the data to be written 1854 + 1831 1831 **Return:** 1832 1832 1833 -Succeed: calculatedresult1857 +Succeed: string: The value of the monitor point before it is written 1834 1834 1835 -Failed: multi, error code 1859 +Failed: nil 1860 + 1861 +== **normal_getdata_byname(string name)** == 1862 + 1863 +**Function:** Read the data of the monitoring point name 1864 + 1865 +**Parameter:** 1866 + 1867 +name: the name of monitoring point 1868 + 1869 +**Return:** 1870 + 1871 +Succeed: string 1872 + 1873 +Failed: nil 1874 + 1875 += **11 MySQL database operation** = 1876 + 1877 +== **luaMySql.init(string sourcename, string username, string password, string host, number port, string character)** == 1878 + 1879 +**Function:** Configure database connection parameters 1880 + 1881 +**Parameter:** 1882 + 1883 +sourcename: the name of database 1884 + 1885 +username: the username of the connection 1886 + 1887 +password: the password of the connection 1888 + 1889 +host: the host name of the connection 1890 + 1891 +port: the host port of the connection 1892 + 1893 +character: the character set of the connection 1894 + 1895 +**Return:** 1896 + 1897 +Succeed: string 1898 + 1899 +Failed: multi 1900 + 1901 +== **luaMySql.exec(string statement)** == 1902 + 1903 +**Function:** Execute the given SQL statement without returning the result set (add, delete, change) 1904 + 1905 +**Parameter:** 1906 + 1907 +statement: the given SQL statement 1908 + 1909 +**Return:** 1910 + 1911 +Succeed: status: returns the number of rows affected by SQL statement execution. 1912 + 1913 +Failed: nil, errorString 1914 + 1915 +== **luaMySql.execWithResult(string statement)** == 1916 + 1917 +**Function:** Execute the given SQL statement returning the result set (check) 1918 + 1919 +**Parameter:** 1920 + 1921 +statement: the given SQL statement 1922 + 1923 +**Return:** 1924 + 1925 +Succeed: table: returns the result set 1926 + 1927 +Failed: nil, errorString 1928 + 1929 +**For example:** 1930 + 1931 +{{code language="LUA"}} 1932 +mysql = require"mysqlclient" 1933 + 1934 +function DataInitRight() 1935 + 1936 +local dbName = "db_lua1" 1937 + 1938 +local user = "root" 1939 + 1940 +local pwd = "123456" 1941 + 1942 +local host = "192.168.56.186" 1943 + 1944 +local port = 3306 1945 +local character = "UTF8" 1946 + 1947 +mysql.init(dbName, user, pwd, host, port, character) 1948 + 1949 +end 1950 + 1951 +function ExecFunc() 1952 + 1953 +status, errorString = mysql.exec("delete from tb_lua1 where mykey = 1954 + 1955 +10;") 1956 + 1957 +if nil == status then 1958 + 1959 +print("ExecFunc() error:", errorString) 1960 + 1961 +return -1 1962 + 1963 +else 1964 + 1965 +print("the number of rows affected by the command:", status) 1966 + 1967 +end 1968 + 1969 +return 0 1970 + 1971 +end 1972 + 1973 +function ExecWithResultFunc() 1974 + 1975 +status, errorString = mysql.execWithResult("select * from tb_lua1;") 1976 + 1977 +if nil == status then 1978 + 1979 +print("ExecWithResultFunc() error:", errorString) 1980 + 1981 +return -1 1982 + 1983 +else 1984 + 1985 +print("ExecWithResultFunc() 1986 + 1987 +success 1988 + 1989 +: status 1990 + 1991 +type 1992 + 1993 += 1994 + 1995 +", 1996 + 1997 +type(status)) 1998 + 1999 +print("ExecWithResultFunc() success : status len = ", #status) 2000 + 2001 +local num = #status 2002 + 2003 +local i = 1 2004 + 2005 +if num > 0 then 2006 + 2007 +for i = 1, num, 1 do 2008 + 2009 +local var = string.format("select result[%d] :mykey = %d, 2010 + 2011 +value = %s", i, status[i].mykey, status[i].value) 2012 + 2013 +print(var) 2014 + 2015 +end 2016 + 2017 +end 2018 + 2019 +print("---------------") 2020 + 2021 +end 2022 + 2023 +return 0 2024 +end 2025 + 2026 +function luaMysql_apiTest.main() 2027 + 2028 +print("script running ...") 2029 + 2030 +DataInitRight() 2031 + 2032 +--use exec demo 2033 + 2034 +if ExecFunc() < 0 then 2035 + 2036 +return 2037 + 2038 +end 2039 + 2040 +--use execWithResult demo 2041 + 2042 +if ExecWithResultFunc() < 0 then 2043 + 2044 +return 2045 + 2046 +end 2047 + 2048 +print("script running success") 2049 + 2050 +end 2051 +{{/code}} 2052 + 2053 += **12 Message summary algorithm** = 2054 + 2055 +== **hmac(string hash_func, string key, string message)** == 2056 + 2057 +**Function:** HMAC calculate 2058 + 2059 +**Function name** 2060 + 2061 +hash_func: 2062 + 2063 +* [md5, sha1, sha224, sha256, sha384, sha512] 2064 +* [sha512_224, sha512_256, sha3_224, sha3_256] 2065 +* [sha3_384, sha3_512] 2066 + 2067 +**Parameter:** 2068 + 2069 +key: the key 2070 + 2071 +message: message content 2072 + 2073 +**Return:** 2074 + 2075 +Succeed: string, calculation result 2076 + 2077 +Failed: nil 2078 + 2079 +**For example:** 2080 + 2081 +{{code language="LUA"}} 2082 +local sha = require"sha2" 2083 + 2084 +function hmac_test.main() 2085 + 2086 +local hmac = sha.hmac 2087 + 2088 +print(hmac(sha.sha1, 2089 + 2090 +"your key", "your message")) 2091 + 2092 +end 2093 +{{/code}} 2094 + 2095 +== **sha(string message** == 2096 + 2097 +**Function:** SHA calculate 2098 + 2099 +**Function name:** 2100 + 2101 +sha: 2102 + 2103 +* sha1, sha224, sha256, sha384, sha512] 2104 +* [sha512_224, sha512_256, sha3_224, sha3_256] 2105 +* [sha3_384, sha3_512] 2106 + 2107 +**Parameter:** 2108 + 2109 +key: the key 2110 + 2111 +message: message content 2112 + 2113 +**Return:** 2114 + 2115 +Succeed: string, calculation result 2116 + 2117 +Failed: nil 2118 + 2119 +For example: 2120 + 2121 +{{code language="LUA"}} 2122 +local sha = require"sha2" 2123 + 2124 +function sha_test.main() 2125 + 2126 +local sha256 = sha.sha256 2127 + 2128 +print(sha256("your message")) 2129 + 2130 +end 2131 +{{/code}}