GPC规范附录:安全通道与密钥管理指南

2星 需积分: 50 33 下载量 82 浏览量 更新于2024-07-17 1 收藏 863KB DOCX 举报
本文档是关于Global Platform (GP) 的规范附录SCP03的中文版本,持续更新中。该附录主要关注于安全通道在智能卡发行和个人化过程中的关键角色,特别是涉及加密密钥的管理和传输安全。安全通道采用伪随机卡挑战的模式,支持离线卡个性化脚本的准备并在无网络连接情况下执行。 核心知识点包括: 1. **安全通道的作用**:在卡发行和个人化阶段,安全通道提供了安全的环境,确保在加密密钥下载过程中传输的安全性。它允许在不依赖实体在线连接的情况下,对卡片进行加密密钥的处理。 2. **传输密钥的强度**:文档强调了密钥管理的重要性,特别是NIST的《Recommendation for Key Management》(NIST 800-57)建议,传输密钥应至少与传输的密钥强度相当。例如,2TDEA密钥可用于加密某些特定类型的密钥,如2TDEA、RSA1024或ECC f=160-223,但有明确的限制,不适用于更高级别的加密算法。 3. **AES密钥的优势**:NIST SP 800-78-1中提及,AES-128、192和256分别适用于加密不同类型的密钥,如3TDEA、RSA小于或等于3072位、AES同级别和ECC f=383以下。这表明AES算法因其灵活性和更强的安全性在传输密钥场景中被推荐。 4. **密钥兼容性和局限性**:文档详细列出了不同密钥类型之间的兼容性,比如3TDEA密钥可以加密其他类似大小的密钥,但不能用于加密更高级别的AES或ECC密钥。这反映了在实际应用中,选择正确的密钥类型和管理策略至关重要。 5. **JavaCard和密钥加载**:由于新版本的JavaCard采用了一些新的加密算法,全球平台提供了一种机制来处理这些新型密钥的加载,这是当前智能卡技术发展中不可忽视的部分。 这份文档是智能卡技术和密钥管理的重要参考资料,它指导着安全通道的设计和实施,以及如何根据NIST标准选择和处理加密密钥,确保在智能卡和个人化过程中数据的安全传输和存储。

DELIMITER $$ CREATE /*[DEFINER = { user | CURRENT_USER }]*/ PROCEDURE `qy_task`.`peopletask`(IN job VARCHAR(200),IN seriesid VARCHAR(200),IN classid VARCHAR(200),IN prodid VARCHAR(200),IN cycleid VARCHAR(200) ) /*LANGUAGE SQL | [NOT] DETERMINISTIC | { CONTAINS SQL | NO SQL | READS SQL DATA | MODIFIES SQL DATA } | SQL SECURITY { DEFINER | INVOKER } | COMMENT 'string'*/ BEGIN #把表围绕id创建一边然后再关联输出数据 CREATE TEMPORARY TABLE IF NOT EXISTS taskpeople SELECT gst.job_number, '' AS AREA, SUM(gst.amount) AS amount, SUM(gst.weight) AS weight, SUM(gst.area) AS AREA, SUM(qsc.weight) AS taskweight, SUM(qsc.weight)/SUM(gst.weight) AS percent FROM qy_goal_salesman_task gst INNER JOIN qy_goal_area_task gat ON gat.id =gst.area_task_id INNER JOIN qy_goal_company_task gct ON gct.id=gst.company_task_id INNER JOIN qy_goal_sale_cycle_config scc ON scc.id=gct.cycle_id INNER JOIN qy_goal_prod_config gpc ON gpc.id=gst.prod_id AND gpc.cycle_id=scc.id INNER JOIN qy_goal_prod_series_config psc ON psc.id=gpc.prod_series_id AND psc.cycle_id=scc.id INNER JOIN qy_goal_prod_classify_config pcc ON pcc.id = psc.prod_type_id AND pcc.cycle_id=scc.id INNER JOIN qy_goal_client_task_detail ctd ON gst.salesman_id=ctd.id INNER JOIN qingyuan.sys_circle sc ON sc.id=ctd.client_id INNER JOIN crm_c_duty_saler duty ON duty.c_id=sc.id INNER JOIN qyng_sys_user qsu ON qsu.id= duty.User_Id LEFT JOIN qy_sys_countydetail qsc ON qsc.proname=Pro_Name WHERE scc.id=cycleid AND qsc.CreateTime>=(SELECT start_date FROM qy_goal_sale_cycle_config WHERE id=cycleid) AND qsc.CreateTime<=(SELECT end_date FROM qy_goal_sale_cycle_config WHERE id=cycleid) AND qsc.GetTime=(SELECT MAX(GetTime) FROM qy_sys_countydetail) AND gpc.id=prodid AND pcc.id=classid AND psc.id=seriesid AND gst.job_number=job GROUP BY gst.job_number; #将临时表进行数据转换 UPDATE taskpeople SET job_number= ff.User_Name FROM taskpeople e INNER JOIN qyqx.qy_staff ff ON e.job_number=ff.uid; #查出真正的表 SELECT * FROM taskpeople; #删除临时表 DROP TEMPORARY TABLE taskpeople; END$$ DELIMITER ;这段mysql存储过程哪里出现了语法错误

2023-05-27 上传