Linux下利用C/C++、shell脚本生成uuid

28 篇文章 0 订阅
5 篇文章 0 订阅

Windows下称为guid,Linux下作为uuid,生成唯一值,可将这种方法用作数据库,作为数据库主键的值。


方法一:利用随机数

#include <stdio.h>
#include <stdlib.h>
#include <string.h>

/**
 * Create random UUID
 *
 * @param buf - buffer to be filled with the uuid string
 */

char *random_uuid( char buf[37] )
{
    const char *c = "89ab";
    char *p = buf;
    int n;
    for( n = 0; n < 16; ++n )
    {
        int b = rand()%255;
        switch( n )
        {
            case 6:
                sprintf(p, "4%x", b%15 );
            break;
            case 8:
                sprintf(p, "%c%x", c[rand()%strlen(c)], b%15 );
            break;
            default:
                sprintf(p, "%02x", b);
            break;
        }
 
        p += 2;
        switch( n )
        {
            case 3:
            case 5:
            case 7:
            case 9:
                *p++ = '-';
                break;
        }
    }
    *p = 0;
    return buf;
}
 
void main()
{
    char guid[37];
    random_uuid(guid);
    printf("guid = %s\n", guid);
    random_uuid(guid);
    printf("guid = %s\n", guid);
    random_uuid(guid);
    printf("guid = %s\n", guid);
    random_uuid(guid);
    printf("guid = %s\n", guid);
}
 

  运行如下:
daniel@debian:~/src$ gcc getuuid.c
daniel@debian:~/src$ ./a.out
guid = a397a255-53be-41fc-996b-521413e9e22d
guid = 518e1f56-0857-49a7-a5d0-528277751b99
guid = 4aed583d-6a52-49d5-b668-8ead955f3c35
guid = b5c48cdd-6c11-453d-91b4-59cfce233d27


方法二:/*libuuid是一个用于生成UUID的C库,具体用法参考http://linux.die.net/man/3/libuuid,在Ubuntu中,可以用下面的命令安装libuuid:
sudo apt-get install uuid-dev

示例如下:*/


#include <stdio.h>
#include <uuid/uuid.h>
int main(int argc, char **argv)
{
    uuid_t uuid;
    char str[36];
 
    uuid_generate(uuid);
    uuid_unparse(uuid, str);
 
    printf("%s\n", str);
 
    return 0;
}
在Linux下编译时需要链接uuid库
gcc -o uuid uuid.c -luuid

  

方式三:利用C++进行封装

参考地址


方式四:shell脚本

#!/bin/bash
 
psd="/proc/sys/kernel/random/uuid"
echo $(cat $psd)


  • 2
    点赞
  • 7
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
当然可以,以下是一个简单的C++程序,可以在Linux下进行经典蓝牙配对: ```cpp #include <bluetooth/bluetooth.h> #include <bluetooth/hci.h> #include <bluetooth/hci_lib.h> #include <bluetooth/sdp.h> #include <bluetooth/sdp_lib.h> #include <unistd.h> #include <iostream> #include <cstring> int main() { // 初始化蓝牙适配器 int dev_id = hci_get_route(NULL); int sock = hci_open_dev(dev_id); if (dev_id < 0 || sock < 0) { std::cerr << "Error opening socket" << std::endl; return 1; } // 扫描附近的蓝牙设备 inquiry_info *info = NULL; int num_rsp = 0; int max_rsp = 255; int flags = IREQ_CACHE_FLUSH; info = (inquiry_info*)malloc(max_rsp * sizeof(inquiry_info)); num_rsp = hci_inquiry(dev_id, 8, max_rsp, NULL, &info, flags); if (num_rsp < 0) { std::cerr << "Error scanning Bluetooth devices" << std::endl; close(sock); return 1; } // 显示扫描到的设备 std::cout << "Found " << num_rsp << " Bluetooth devices:" << std::endl; for (int i = 0; i < num_rsp; i++) { char addr[19] = { 0 }; ba2str(&(info+i)->bdaddr, addr); std::cout << addr << std::endl; } // 选择要配对的设备 std::cout << "Enter the address of the device you want to pair with: "; char addr[19] = { 0 }; std::cin >> addr; // 连接到设备 bdaddr_t target; str2ba(addr, &target); int status = hci_create_connection(sock, &target, HCI_CHANNEL_RAW, 0); if (status < 0) { std::cerr << "Error connecting to device" << std::endl; close(sock); return 1; } // 获取设备的SDP服务记录 sdp_session_t *session = sdp_connect(BDADDR_ANY, &target, SDP_RETRY_IF_BUSY); if (!session) { std::cerr << "Error connecting to SDP server" << std::endl; hci_disconnect(sock, status); close(sock); return 1; } sdp_list_t *response_list = NULL; uint32_t range = 0x0000ffff; uint32_t max_count = 0xffffffff; uint8_t service_uuid[] = { 0x11, 0x11, 0x11, 0x11, 0x11, 0x11, 0x11, 0x11, 0x11, 0x11, 0x11, 0x11, 0x11, 0x11, 0x11, 0x11 }; sdp_uuid128_create(&service_uuid, &service_uuid); sdp_uuid128_add(&service_uuid, range); sdp_list_t *search_list = sdp_list_append(NULL, &service_uuid); sdp_list_t *attr_list = sdp_list_append(NULL, &range); status = sdp_service_search_attr_req(session, search_list, SDP_ATTR_REQ_RANGE, attr_list, &response_list); if (status < 0) { std::cerr << "Error getting SDP service record" << std::endl; sdp_close(session); hci_disconnect(sock, status); close(sock); return 1; } // 读取SDP服务记录 sdp_record_t *record = NULL; sdp_list_t *r = response_list; for (; r; r = r->next) { record = (sdp_record_t*)r->data; sdp_list_t *proto_list = NULL; status = sdp_get_access_protos(record, &proto_list); if (status < 0) { std::cerr << "Error getting protocols for service record" << std::endl; sdp_list_free(search_list, NULL); sdp_list_free(attr_list, NULL); sdp_list_free(proto_list, NULL); sdp_close(session); hci_disconnect(sock, status); close(sock); return 1; } // 检查SDP服务记录是否支持RFCOMM协议 sdp_list_t *p = proto_list; for (; p; p = p->next) { uint8_t protocol = 0; sdp_get_proto_param(p->data, &protocol); if (protocol == RFCOMM_UUID) { sdp_list_free(search_list, NULL); sdp_list_free(attr_list, NULL); sdp_list_free(proto_list, NULL); sdp_close(session); hci_disconnect(sock, status); close(sock); // 建立RFCOMM连接 uint8_t channel = 0; sdp_get_rfcomm_channel(p->data, &channel); sockaddr_rc addr = { 0 }; addr.rc_family = AF_BLUETOOTH; addr.rc_channel = channel; bacpy(&addr.rc_bdaddr, &target); int rfcomm = socket(AF_BLUETOOTH, SOCK_STREAM, BTPROTO_RFCOMM); status = connect(rfcomm, (sockaddr*)&addr, sizeof(addr)); if (status < 0) { std::cerr << "Error connecting RFCOMM socket" << std::endl; return 1; } // 配对成功 std::cout << "Pairing successful" << std::endl; return 0; } } sdp_list_free(proto_list, NULL); } sdp_list_free(search_list, NULL); sdp_list_free(attr_list, NULL); sdp_close(session); // 设备不支持RFCOMM协议 std::cerr << "Device does not support RFCOMM protocol" << std::endl; hci_disconnect(sock, status); close(sock); return 1; } ``` 这个程序会扫描附近的蓝牙设备,然后要求用户选择要配对的设备。它会连接到设备并获取它的SDP服务记录,然后检查SDP服务记录是否支持RFCOMM协议。如果支持,它会建立RFCOMM连接,然后配对成功。否则,它会输出错误消息并退出。要编译这个程序,可以使用以下命令: ``` g++ -o bluetooth-pair bluetooth-pair.cpp -lbluetooth ``` 这个程序需要root权限才能运行。

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值