DingTalk 인터페이스 및 PHP 출근 애플리케이션 개발 가이드
DingTalk가 기업 사무실 및 관리의 주요 도구로 인기를 끌면서 많은 회사에서 DingTalk를 사용하여 직원 출근 기록을 완성하기를 희망하고 있습니다. 기업의 요구 사항을 충족하기 위해 DingTalk에서 제공하는 인터페이스를 사용하여 자체 출근 애플리케이션을 개발할 수 있습니다. 이 기사에서는 PHP 언어를 사용하여 간단한 DingTalk 체크인 애플리케이션을 개발하는 방법을 소개하고 관련 코드 예제를 제공합니다.
1. 준비
시작하기 전에 다음 자료를 준비해야 합니다.
2. 인터페이스 인증
DingTalk의 인터페이스를 호출하려면 먼저 인증을 받고 액세스 토큰을 얻어야 합니다. 다음은 HTTP 요청을 통해 액세스 토큰을 얻기 위한 간단한 PHP 함수입니다.
function getAccessToken($appKey, $appSecret) { $url = "https://oapi.dingtalk.com/gettoken?appkey={$appKey}&appsecret={$appSecret}"; $result = json_decode(file_get_contents($url), true); return $result['access_token']; }
이 함수에서는 HTTP GET 요청을 통해 DingTalk의 토큰 획득 인터페이스에 요청을 보내고 매개변수에는 appKey 및 appSecret이 포함됩니다. 인터페이스는 JSON 형식으로 결과를 반환하며, 우리는 access_token 필드를 구문 분석하고 반환합니다.
3. 사용자 정보 얻기
출근 작업을 수행하기 전에 먼저 출근해야 할 직원의 사용자 ID를 얻어야 합니다. 다음은 지정된 직원의 사용자 ID를 가져오는 함수의 예입니다.
function getUserId($accessToken, $code) { $url = "https://oapi.dingtalk.com/user/getuserinfo?access_token={$accessToken}&code={$code}"; $result = json_decode(file_get_contents($url), true); return $result['userid']; }
이 함수에서는 HTTP GET 요청을 통해 DingTalk의 사용자 정보 획득 인터페이스에 요청을 보냅니다. 매개변수에는 액세스 토큰과 직원의 임시 권한이 포함됩니다. 코드(이 코드는 직원이 승인 링크를 클릭한 후에 얻을 수 있습니다). 인터페이스는 JSON 형식으로 결과를 반환하며, 사용자 ID 필드를 구문 분석하고 반환합니다.
4. 펀치인 작업
사용자 ID를 획득한 후 출근 인터페이스를 호출하여 직원 출근 기능을 구현할 수 있습니다. 다음은 직원 출근을 구현하는 샘플 함수입니다.
function clockIn($accessToken, $userId, $recordTime, $type) { $url = "https://oapi.dingtalk.com/attendance/list?access_token={$accessToken}"; $data = [ 'userIds' => [$userId], 'checkDateFrom' => $recordTime, 'checkDateTo' => $recordTime, 'isI18n' => 'false', 'isIncludeLeave' => 'false', 'isIncludeHoliday' => 'false', 'isIncludeRecall' => 'false', 'isIncludeMiss' => 'false', 'isIncludeNotSignedOff' => 'true', 'isIncludeNotSignedOff' => 'true' ]; $result = json_decode(http_post($url, json_encode($data)), true); return $result; }
이 함수에서는 HTTP POST 요청을 통해 DingTalk의 출근 인터페이스에 요청을 보냅니다. 매개변수에는 액세스 토큰, 직원의 사용자 ID, 녹음이 포함됩니다. 시간 기록 시간 및 출근 인터페이스 유형입니다. 인터페이스는 직원의 펀치인 기록 정보가 포함된 JSON 형식의 결과를 반환합니다.
위의 예에는 HTTP POST 요청을 보내는 데 사용되는 http_post 함수가 포함되어 있습니다. 다음은 http_post 함수의 간단한 구현 예입니다.
function http_post($url, $data) { $curl = curl_init(); curl_setopt($curl, CURLOPT_URL, $url); curl_setopt($curl, CURLOPT_POST, 1); curl_setopt($curl, CURLOPT_POSTFIELDS, $data); curl_setopt($curl, CURLOPT_RETURNTRANSFER, 1); $result = curl_exec($curl); curl_close($curl); return $result; }
5. 통합 예
이제 위의 기능을 통합하여 완전한 DingTalk 펀치인 응용 프로그램 예를 구현해 보겠습니다. 다음은 DingTalk 콜백 요청을 처리하는 데 사용되는 간단한 PHP 스크립트입니다.
<?php $appKey = "your_app_key"; $appSecret = "your_app_secret"; $code = $_GET['code']; $accessToken = getAccessToken($appKey, $appSecret); $userId = getUserId($accessToken, $code); $recordTime = date("Y-m-d", strtotime("-1 days")); $result = clockIn($accessToken, $userId, $recordTime, "OnDuty"); var_dump($result);
위 예제 코드에서는 먼저 콜백 요청에서 인증 코드 코드를 얻은 후 인증 코드를 통해 사용자 ID를 얻습니다. 그런 다음, 현재 시간보다 하루 전 날짜를 녹음 시간으로 삼고 펀치인 함수를 호출하여 해당 직원의 펀치인 기록 정보를 가져옵니다. 마지막으로 var_dump 함수를 통해 펀치인 기록 정보의 결과를 출력한다.
6. 요약
이 글에서는 PHP 언어를 사용하여 간단한 DingTalk 체크인 애플리케이션을 개발하는 방법을 소개합니다. DingTalk에서 제공하는 인터페이스를 호출하여 직원 펀치인 기록을 획득하고 처리할 수 있습니다. DingTalk가 지속적으로 개발 및 업그레이드됨에 따라 이 문서의 샘플 코드를 기반으로 더욱 확장하고 최적화하여 보다 복잡한 비즈니스 요구 사항을 충족할 수 있습니다. 이 글이 여러분의 DingTalk 개발과 어플리케이션 개발에 도움이 되기를 바랍니다!
위 내용은 DingTalk 인터페이스 및 PHP 체크인 애플리케이션 개발 가이드의 상세 내용입니다. 자세한 내용은 PHP 중국어 웹사이트의 기타 관련 기사를 참조하세요!