◆ 嵌入式系統,獨立操作,內建完整系統
◆ 支援紅外掌靜脈認證模式,免摘口罩非接觸
◆ 雙紅外線人臉活體識別模組,獨立人臉運算晶片
◆ 內建指紋、MiFare(IC卡)卡及密碼驗證
◆ 多項特徵碼打卡可選,避免代打卡問題
◆ 分散部署架構,輕鬆建立各單位統合考勤報表
◆ 支援手機GPS打卡,高效更富有科技感
◆ 手機App直接查看考勤狀態,部門出勤一手掌握
◆ 透過手機直接進行請假差勤,人資管理資訊化
◆ 完善的雲端後台考勤管理,免設定維護
◆ 便捷的線上”視圖排班”可滿足複雜的彈性排班
◆ 可自行定義請假差勤審核流程,讓流程雲端化
◆ 統合所有mOA雲考勤的數據資料,形成總報表
◆ 支援Web介面,可產出統計報表,並匯出成EXCEL
類型 | 檔名/說明 | 更新日期 | 下載 |
---|---|---|---|
產品型錄 | mOA雲考勤(450)_BS_A4-DM_20200821.pdf | 2020-08-21 | |
使用手冊 | mK450(BS)掌靜脈人臉指紋門禁考勤機說明書_20200524.pdf | 20200524.pdf | |
[產品型錄] | mOA雲考勤(450)_BS_A4-DM_20200821.pdf | 2020-08-21 |
技術支援服務 Technical Support
(服務時間:週一至週五 9:00 ~ 18:00 中午 12:00 ~ 13:30 休息)
客服專線:+886-2-22259208#119
產品銷售諮詢 Sales & Marketing
(服務時間:週一至週五 9:00 ~ 18:00 中午 12:00 ~ 13:30 休息)
業務專線:+886-2-22259208#258
地址:235 新北市中和區中正路872號13樓之1
Line
或請加入Line@mici讓我們為您服務
WEBAPP本地運行正常,但是上傳到伺務器 GPS打卡失敗
javax.net.ssl.SSLHandshakeException: No appropriate protocol (protocol is disabled or cipher suites are inappropriate)at com.sun.mail.smtp.SMTPTransport.openServer(SMTPTransport.java:1972)at com.sun.mail.smtp.SMTPTransport.protocolConnect(SMTPTransport.java:642)at javax.mail.Service.connect(Service.java:317)at javax.mail.Service.connect(Service.java:176)at javax.mail.Service.connect(Service.java:125)at javax.mail.Transport.send0(Transport.java:194)at javax.mail.Transport.send(Transport.java:124)
1 jdk目錄/jre/lib/security/java.security,去掉jdk.tls.disabledAlgorithm中的SSLv3、TLSv1、TLSv1.1
2 執行以下命令
update-crypto-policies --set LEGACY
]]>
類型檔名/說明更新日期下載
[產品型錄]mK520_DM-2020617.pdf2020-06-19
download
[使用手冊]mK520P快速安裝說明書.pdf2020-06-19
download
<mapper namespace="com.itheima.mapper.testMapper" >
必須指定對應的mapper代理接口全路徑;
<select id="findPojo" resultType="com.itheima.pojo.TestPojo"> SELECT * FROM zxc </select><mapper namespace="com.itheima.mapper.testMapper" >
必須指定對應的mapper代理接口全路徑;
<select id="findPojo" resultType="com.itheima.pojo.TestPojo"> SELECT * FROM zxc </select>
id對應mapper中的方法;執行這次查詢的方法
]]>需要提升 Webhook 伺服器的安全環境,這邊也提醒大家根據 2021/01 的新聞 ([Updated] TLS 1.0 and TLS 1.1 support by the webhook notification source will be discontinued at the end of January 2021),如果要能正常地接受到 LINE 平台的 Webhook 必須要讓伺服器支援到 TLS 1.3 。
平台開始支援 TLS 1.3 LINE’s APIs now support TLS 1.3
將不支援 TLS 1.0 與 1.1 (參考新聞: Updated: TLS 1.0 and TLS 1.1 support by the webhook notification source will be discontinued at the end of January 2021 )
第一件事:正確設定HTTPS from 在 「開發LINE聊天機器人不可不知的十件事」 也有提到相關的支援,請開發者們務必要注意。
在設定HTTPS伺服器時,有下列幾點必須注意的事項:
HTTPS伺服器所使用的根憑證(Root CA)必須是在LINE平台的白名單列表中,否則LINE平台會拒絕傳送訊息。在白名單列表中大多數的憑證都需要付費申請,但是LINE平台也支援常用的免費憑證,例如Let’s Encrypt。
請勿使用已知具有安全性漏洞的協定(例如SSL v2或SSL v3)或Cipher Suite(例如SWEET32或CVE-2016-2183)。
請務必正確設定中繼憑證(Intermediate certificate),以避免無法對應到根憑證而發生錯誤。這是最常見的問題通報狀況,請在設定HTTPS伺服器時多加留意。
更多訊息歡迎參考以下文章:
在 「開發LINE聊天機器人不可不知的十件事」的文章的(第三件事:盡快回覆LINE平台正確的HTTP狀態碼). 中,也有提到 LINE平台在傳送事件訊息到開發者Webhook伺服器之後,若是等待1秒鐘沒有得到任何HTTP狀態碼的回覆,就會發生逾時(Timeout)錯誤,LINE平台會關閉該次HTTP連線並認為該次傳送結果失敗;若是一直發生傳送失敗的狀況,LINE平台可能會將該Webhook伺服器封鎖或進行其他處置,造成開發者的應用服務無法正常運作。 請開發者們要注意到相關的事項。
更多訊息歡迎參考以下文章:
在 「開發LINE聊天機器人不可不知的十件事」的文章中(第二件事:驗證訊息來源)也有提到,當開發者的Webhook伺服器收到以POST方式所傳送的LINE事件訊息時,必須要立即驗證該事件訊息是否真的來自LINE平台,以避免被偽造的訊息所欺騙造成資訊安全危機。標準的驗證方式是檢查所收到HTTP請求標頭(HTTP request header)中的數位簽章。如果該HTTP POST訊息是來自LINE平台,在HTTP請求標頭中一定會包括X-Line-Signature項目,該項目的內容值是即為數位簽章。
更多訊息歡迎參考以下文章:
這邊有分享一些給開發者的經驗分享,根據業務的發展狀況下,以下幾個時間將會有大量的訊息灌入開發者們的 LINE Bot ,希望開發者們可能要注意到。 (訊息集中的部分)
針對這些大量的訊息可能湧入下,建議開發者們必須要有相關的備案需求。避免因為訊息過多而造成開發者的伺服器不堪負荷。 建議如下:
是否有水平擴張的機制來面對大量的需求。 (Auto-scaling)
建議檢查每一次訊息來之後的回覆時間,儘量採取非同步方式。盡可能先回覆之後,在另外發訊息給使用者。如此一來可以避免卡住太多訊息。
此外,本頁投影片也告知幾個重要消息:
這邊提到的是切換 Webhook 開關跟「自動回覆訊息」還有「加入好友的歡迎訊息」的解釋。 這邊主要提醒開發者們,如果忘記將「自動回覆訊息」關閉的話,即便你開起來 Webhook 的開關,雖然可以收到,還是會透過「自動回覆訊息」來回覆。 相關的細節在下一頁會有更多解釋:
相關資料:
使用「Webhook],使用自動回覆與加入好友歡迎訊息:
訊息來了,同時會送到 Webhook 與自動回覆。
但是因為自動回覆會先回覆,Webhook 不需要再回覆即可。
使用「Webhook],不使用自動回覆與加入好友歡迎訊息:
不使用「Webhook],使用自動回覆與加入好友歡迎訊息:
不使用「Webhook],不使用自動回覆與加入好友歡迎訊息:
在 「開發LINE聊天機器人不可不知的十件事」的文章中(第四件事:LINE平台所傳送的事件是一個陣列) 有更多清楚解釋,歡迎大家去了解一下。 因為 Messaging API 帳號沒有大量的事件訊息傳入,每次所收到事件幾乎都只有一筆資料,所以開發者會誤以為每個事件訊息只需要處理一筆資料。事實上,LINE平台傳送給Webhook伺服器的HTTP請求本體是包括一個或多個Webhook事件物件的JSON格式物件
這邊有建議開發者們,對於屬性的判斷上儘量要當成獨立個體之外,對於可能的新增屬性建議也要有比較好的處理方式。 建議方式可以透過 switch case 的方式來判斷,僅僅對於有處理的事件(event) 來處理,其他都略過。
相關文件:
在 「開發LINE聊天機器人不可不知的十件事」的文章中(第二件事:驗證訊息來源) 有更多清楚解釋。文章中建議驗證方式如下:
以Channel secret作為密鑰(Secret key),使用HMAC-SHA256演算法取得HTTP請求本體(HTTP request body)的文摘值(Digest value)。
將上述文摘值以Base64編碼,比對編碼後的內容與X-Line-Signature項目內容值是否相同;若是相同,表示該事件訊息是來自LINE平台,否則拒絕處理該事件訊息。
相關文件:
在 「開發LINE聊天機器人不可不知的十件事」的文章中(第三件事:盡快回覆LINE平台正確的HTTP狀態碼) ,在此僅列出相關流程圖,更多內容歡迎各位去部落格查看。
這部分可以參考以下的流程圖:
這邊是敘述說如果 LINE 平台有問題發生的時候(或是無法正確收到開發者的回覆時),將會另行發信給開發者的信箱中。相關的信件內中如文件上。
參考以下文章:
]]>斷言是一個邏輯判斷,用於檢查不應該發生的情況
Assert 關鍵字在 JDK1.4 中引入,可通過 JVM 參數-enableassertions
開啟
SpringBoot 中提供了 Assert 斷言工具類,通常用於數據合法性檢查
// 要求參數 object 必須為非空(Not Null),否則拋出異常,不予放行// 參數 message 參數用於定製異常信息。void notNull(Object object, String message)// 要求參數必須空(Null),否則拋出異常,不予『放行』。// 和 notNull() 方法斷言規則相反void isNull(Object object, String message)// 要求參數必須為真(True),否則拋出異常,不予『放行』。void isTrue(boolean expression, String message)// 要求參數(List/Set)必須非空(Not Empty),否則拋出異常,不予放行void notEmpty(Collection collection, String message)// 要求參數(String)必須有長度(即,Not Empty),否則拋出異常,不予放行void hasLength(String text, String message)// 要求參數(String)必須有內容(即,Not Blank),否則拋出異常,不予放行void hasText(String text, String message)// 要求參數是指定類型的實例,否則拋出異常,不予放行void isInstanceOf(Class type, Object obj, String message)// 要求參數 `subType` 必須是參數 superType 的子類或實現類,否則拋出異常,不予放行void isAssignable(Class superType, Class subType, String message)
// 獲取對象的類名。參數為 null 時,返回字符串:"null" String nullSafeClassName(Object obj)// 參數為 null 時,返回 0int nullSafeHashCode(Object object)// 參數為 null 時,返回字符串:"null"String nullSafeToString(boolean[] array)// 獲取對象 HashCode(十六進製形式字符串)。參數為 null 時,返回 0 String getIdentityHexString(Object obj)// 獲取對象的類名和 HashCode。 參數為 null 時,返回字符串:"" String identityToString(Object obj)// 相當於 toString()方法,但參數為 null 時,返回字符串:""String getDisplayString(Object obj)
// 判斷數組是否為空boolean isEmpty(Object[] array)// 判斷參數對象是否是數組boolean isArray(Object obj)// 判斷數組中是否包含指定元素boolean containsElement(Object[] array, Object element)// 相等,或同為 null時,返回 trueboolean nullSafeEquals(Object o1, Object o2)/*判斷參數對象是否為空,判斷標準為: Optional: Optional.empty() Array: length == 0CharSequence: length == 0 Collection: Collection.isEmpty() Map: Map.isEmpty() */boolean isEmpty(Object obj)
// 向參數數組的末尾追加新元素,並返回一個新數組<A, O extends A> A[] addObjectToArray(A[] array, O obj)// 原生基礎類型數組 --> 包裝類數組Object[] toObjectArray(Object source)
// 判斷字符串是否為 null,或 ""。註意,包含空白符的字符串為非空boolean isEmpty(Object str)// 判斷字符串是否是以指定內容結束。忽略大小寫boolean endsWithIgnoreCase(String str, String suffix)// 判斷字符串是否已指定內容開頭。忽略大小寫boolean startsWithIgnoreCase(String str, String prefix) // 是否包含空白符boolean containsWhitespace(String str)// 判斷字符串非空且長度不為 0,即,Not Emptyboolean hasLength(CharSequence str)// 判斷字符串是否包含實際內容,即非僅包含空白符,也就是 Not Blankboolean hasText(CharSequence str)// 判斷字符串指定索引處是否包含一個子串。boolean substringMatch(CharSequence str, int index, CharSequence substring)// 計算一個字符串中指定子串的出現次數int countOccurrencesOf(String str, String sub)
// 查找並替換指定子串String replace(String inString, String oldPattern, String newPattern)// 去除尾部的特定字符String trimTrailingCharacter(String str, char trailingCharacter) // 去除頭部的特定字符String trimLeadingCharacter(String str, char leadingCharacter)// 去除頭部的空白符String trimLeadingWhitespace(String str)// 去除頭部的空白符String trimTrailingWhitespace(String str)// 去除頭部和尾部的空白符String trimWhitespace(String str)// 刪除開頭、結尾和中間的空白符String trimAllWhitespace(String str)// 刪除指定子串String delete(String inString, String pattern)// 刪除指定字符(可以是多個)String deleteAny(String inString, String charsToDelete)// 對數組的每一項執行 trim() 方法String[] trimArrayElements(String[] array)// 將 URL 字符串進行解碼String uriDecode(String source, Charset charset)
// 解析路徑字符串,優化其中的 「..」 String cleanPath(String path)// 解析路徑字符串,解析出文件名部分String getFilename(String path)// 解析路徑字符串,解析出文件後綴名String getFilenameExtension(String path)// 比較兩個兩個字符串,判斷是否是同一個路徑。會自動處理路徑中的 「..」 boolean pathEquals(String path1, String path2)// 刪除文件路徑名中的後綴部分String stripFilenameExtension(String path) // 以 「. 作為分隔符,獲取其最後一部分String unqualify(String qualifiedName)// 以指定字符作為分隔符,獲取其最後一部分String unqualify(String qualifiedName, char separator)
// 判斷 List/Set 是否為空boolean isEmpty(Collection<?> collection)// 判斷 Map 是否為空boolean isEmpty(Map<?,?> map)// 判斷 List/Set 中是否包含某個對象boolean containsInstance(Collection<?> collection, Object element)// 以叠代器的方式,判斷 List/Set 中是否包含某個對象boolean contains(Iterator<?> iterator, Object element)// 判斷 List/Set 是否包含某些對象中的任意一個boolean containsAny(Collection<?> source, Collection<?> candidates)// 判斷 List/Set 中的每個元素是否唯一。即 List/Set 中不存在重復元素boolean hasUniqueObject(Collection<?> collection)
// 將 Array 中的元素都添加到 List/Set 中<E> void mergeArrayIntoCollection(Object array, Collection<E> collection) // 將 Properties 中的鍵值對都添加到 Map 中<K,V> void mergePropertiesIntoMap(Properties props, Map<K,V> map)// 返回 List 中最後一個元素<T> T lastElement(List<T> list) // 返回 Set 中最後一個元素<T> T lastElement(Set<T> set) // 返回參數 candidates 中第一個存在於參數 source 中的元素<E> E findFirstMatch(Collection<?> source, Collection<E> candidates)// 返回 List/Set 中指定類型的元素。<T> T findValueOfType(Collection<?> collection, Class<T> type)// 返回 List/Set 中指定類型的元素。如果第一種類型未找到,則查找第二種類型,以此類推Object findValueOfType(Collection<?> collection, Class<?>[] types)// 返回 List/Set 中元素的類型Class<?> findCommonElementType(Collection<?> collection)
// 從文件中讀入到字節數組中byte[] copyToByteArray(File in)// 從輸入流中讀入到字節數組中byte[] copyToByteArray(InputStream in)// 從輸入流中讀入到字符串中String copyToString(Reader in)
// 從字節數組到文件void copy(byte[] in, File out)// 從文件到文件int copy(File in, File out)// 從字節數組到輸出流void copy(byte[] in, OutputStream out) // 從輸入流到輸出流int copy(InputStream in, OutputStream out) // 從輸入流到輸出流int copy(Reader in, Writer out)// 從字符串到輸出流void copy(String in, Writer out)
// 判斷字符串是否是一個合法的 URL 字符串。static boolean isUrl(String resourceLocation)// 獲取 URLstatic URL getURL(String resourceLocation) // 獲取文件(在 JAR 包內無法正常使用,需要是一個獨立的文件)static File getFile(String resourceLocation)
// 文件系統資源 D:\...FileSystemResource// URL 資源,如 file://... http://...UrlResource// 類路徑下的資源,classpth:...ClassPathResource// Web 容器上下文中的資源(jar 包、war 包)ServletContextResource
// 判斷資源是否存在boolean exists()// 從資源中獲得 File 對象File getFile()// 從資源中獲得 URI 對象URI getURI()// 從資源中獲得 URI 對象URL getURL()// 獲得資源的 InputStreamInputStream getInputStream()// 獲得資源的描述信息String getDescription()
void copy(byte[] in, OutputStream out)int copy(InputStream in, OutputStream out)void copy(String in, Charset charset, OutputStream out)long copyRange(InputStream in, OutputStream out, long start, long end)
byte[] copyToByteArray(InputStream in)String copyToString(InputStream in, Charset charset)// 舍棄輸入流中的內容int drain(InputStream in)
// 在類中查找指定方法Method findMethod(Class<?> clazz, String name) // 同上,額外提供方法參數類型作查找條件Method findMethod(Class<?> clazz, String name, Class<?>... paramTypes) // 獲得類中所有方法,包括繼承而來的Method[] getAllDeclaredMethods(Class<?> leafClass) // 在類中查找指定構造方法Constructor<T> accessibleConstructor(Class<T> clazz, Class<?>... parameterTypes) // 是否是 equals() 方法boolean isEqualsMethod(Method method) // 是否是 hashCode() 方法 boolean isHashCodeMethod(Method method) // 是否是 toString() 方法boolean isToStringMethod(Method method) // 是否是從 Object 類繼承而來的方法boolean isObjectMethod(Method method) // 檢查一個方法是否聲明拋出指定異常boolean declaresException(Method method, Class<?> exceptionType)
// 執行方法Object invokeMethod(Method method, Object target) // 同上,提供方法參數Object invokeMethod(Method method, Object target, Object... args) // 取消 Java 權限檢查。以便後續執行該私有方法void makeAccessible(Method method) // 取消 Java 權限檢查。以便後續執行私有構造方法void makeAccessible(Constructor<?> ctor)
// 在類中查找指定屬性Field findField(Class<?> clazz, String name) // 同上,多提供了屬性的類型Field findField(Class<?> clazz, String name, Class<?> type) // 是否為一個 "public static final" 屬性boolean isPublicStaticFinal(Field field)
// 獲取 target 對象的 field 屬性值Object getField(Field field, Object target) // 設置 target 對象的 field 屬性值,值為 valuevoid setField(Field field, Object target, Object value) // 同類對象屬性對等賦值void shallowCopyFieldState(Object src, Object dest)// 取消 Java 的權限控製檢查。以便後續讀寫該私有屬性void makeAccessible(Field field) // 對類的每個屬性執行 callbackvoid doWithFields(Class<?> clazz, ReflectionUtils.FieldCallback fc) // 同上,多了個屬性過濾功能。void doWithFields(Class<?> clazz, ReflectionUtils.FieldCallback fc, ReflectionUtils.FieldFilter ff) // 同上,但不包括繼承而來的屬性void doWithLocalFields(Class<?> clazz, ReflectionUtils.FieldCallback fc)
// 判斷是不是 Spring 代理對象boolean isAopProxy()// 判斷是不是 jdk 動態代理對象isJdkDynamicProxy()// 判斷是不是 CGLIB 代理對象boolean isCglibProxy()
// 獲取被代理的目標 classClass<?> getTargetClass()
Object currentProxy()
]]>
◆ 嵌入式系統,獨立操作,內建完整系統
◆ 節省主機架設費用及每年維護費
◆ 2.8吋觸控式電容面板,設定簡易操作直覺
◆ 內建指紋、IC卡刷卡及密碼功能,支援悠遊卡
◆ 分散部署架構,輕鬆建立各單位統合考勤報表
◆ 支援手機GPS打卡,高效更富有科技感
◆ 手機App直接查看考勤狀態,部門出勤一手掌握
◆ 透過手機直接進行請假差勤,人資管理資訊化
◆ 完善的雲端後台考勤管理,免設定維護
◆ 提供7層組織架構,並可分層分權定義管理權限
◆ 支援彈性視圖排班,可依個人自定義排班方式
◆ 可自行定義請假差勤審核流程,讓流程雲端化
◆ 統合所有mOA雲考勤的數據資料,形成總報表
◆ 支援Web介面,可產出統計報表,並匯出成EXCEL
類型檔名/說明更新日期下載
[產品型錄]mK315雲考勤_DM_20220422.pdf2022-04-22
[使用手冊]mK315(BS)指紋卡片考勤門禁機說明書_20220408.pdf2022-04-08
[安裝手冊]mK315接線圖.pdf2022-04-08
請依您的需求選擇相關技術支援服務,若有其他問題請與我們聯繫謝謝!
遠端線上支援程式
保固服務
產品保固說明。
相關問題
產品相關問題說明。
下載專區
軟體更新:提供最新版本的驅動程式及韌體,產品可以透過驅動程式或韌體更新,取得新功能或增加穩定性。應用軟體:提供使用產品時所需之工具軟體。 產品型錄:提供詳細的產品規格及介紹。 使用手冊:提供詳細的產品功能操作使用說明。 快速安裝手冊:提供簡短的操作步驟, Step-by-step 引導您快速完成產品安裝。 使用教學影片:提供實際產品操作畫面。
]]>
◆ 2.4吋TFT觸控式電容面板,人機交互操作直覺且簡易
◆ SOC 32位元嵌入式架構,獨立操作,內建完整系統
◆ 提供有線、無線網路進行連網,同時具斷線備存功能
◆ 獨家專利紙卡卡片識別技術,單機可支援999個員工
◆ 分散部署集中統一管理架構,輕鬆統合單位考勤報表
◆ 手機APP即時查看員工考勤狀態,出勤狀態一手掌握
◆ 大型機械鐘面及LCD同步顯示,一目了然、清晰易懂
◆ 紅、黑雙色九針點矩陣式列印,清晰易讀,堅固耐用
◆ 全自動判斷紙卡正、反面及員工卡號識別,避免錯誤
◆ 透過手機可自行定義設備時區,自動校時,全球通用
◆ 支援一組外接響鈴,並有多組內建響鈴音樂可供選擇
◆ 具打卡連動功能,可外接攝影機進行拍照或門禁控制
◆ 手機一鍵產出當月統計報表,並可自動匯出成EXCEL