简介:
《Practical Common Lisp笔记》是一本深入探讨Common Lisp编程语言的实用教程。
Common Lisp是一种功能强大的多范式编程语言,以其动态类型、宏系统和丰富的内置数据结构而闻名。
这篇笔记详细记录了作者在学习过程中的理解和实践,旨在帮助读者掌握这一高级语言。
博文链接提供的资源是一个关于Common Lisp的在线阅读版本,它可能包含了代码示例、解释和作者对语言特性的见解。
文件"practical_common_lisp.html"很可能是这篇笔记的网页版,而"practical_common_lisp"可能是与之相关的源代码或补充材料。
Common Lisp的重要知识点包括:1. **动态类型**:与静态类型语言不同,Common Lisp允许在程序运行时改变变量的类型,这提供了更大的灵活性。
2. **宏系统**:Common Lisp的宏是语言的一部分,允许程序员定义新的语法结构,增强了代码的可读性和复用性。
3. **符号和原子性**:在Common Lisp中,符号是第一类对象,且不可变,这意味着它们可以被用作变量、函数名等。
4. **列表和S-表达式**:Common Lisp的基础数据结构是列表,S-表达式(Symbolic Expression)是其语法基础,所有程序都以列表形式表示。
5. **标准库**:Common Lisp有一个庞大的标准库,包含各种数据结构、算法和系统接口,如CL-PPCRE(正则表达式)、ASDF(应用程序定义和分发系统)等。
6. **条件系统和多重异常处理**:通过条件系统,开发者可以编写优雅的异常处理代码,应对各种错误情况。
7. **函数式编程**:Common Lisp支持高阶函数、尾递归优化和匿名函数,使得函数式编程风格得以流畅实现。
8. **面向对象编程**:虽然不是其核心特性,但Common Lisp提供CLOS(Common Lisp Object System),一个完全集成的、可扩展的面向对象系统。
9. **元编程**:由于其强大的宏系统和反射能力,Common Lisp支持元编程,可以在运行时修改和生成代码。
10. **并行和并发**:Common Lisp有内建的支持多线程和并发的机制,允许开发者利用多核处理器的优势。
通过阅读《Practical Common Lisp笔记》,读者可以了解如何利用这些特性来构建复杂的应用程序,同时也能深入理解Common Lisp的强大之处。
对于想要提升编程技能,特别是对动态语言和元编程感兴趣的开发者来说,这是一个宝贵的资源。
2025/6/15 19:55:55 57KB
1
简介:
使用gandi.net LiveDNS API动态更新域的DNS A记录的Python脚本: 该脚本是为动态IP接口(例如家庭服务器/ pi / nas)背后的人员开发的。
config-template.txt文件应重命名为config.txt,并使用gandi.net API密钥,域名和A记录(@,dev,home,pi等)进行修改。
每次脚本运行时,它将查询外部服务以检索计算机的外部IP,将其与gandi.net区域中的当前A记录进行比较,如果IP已更改,则更新记录。
要求: 点安装-r requirements.txt 然后,您可以将脚本作为cron作业运行: */15 * * * * python /home/user/gandi_ddns.py但是,为了使API服务器更好用,您应该为您的工作选择一个随机偏移量。
例如,在小时后的2分钟运行,然后每15分钟运行一
2025/6/15 19:53:28 5KB
1
简介:
### CAS单点登录服务器配置详解#### 一、CAS单点登录概述CAS(Central Authentication Service)是一种开放源代码的单点登录协议和服务框架,它为Web应用提供了一种简化了的身份验证流程。
通过CAS,用户只需要在一个地方完成登录过程,即可在多个应用间共享登录状态,无需重复登录。
#### 二、CAS服务器安装与配置##### 2.1 安装CAS服务端1. **下载CAS服务端**:首先从官方网址http://www.cas.org/下载最新的CAS服务端压缩包。
2. **部署WAR包**:将下载的WAR包复制到Tomcat的webapps目录下,并将其重命名为`cas.war`。
3. **启动Tomcat**:启动Tomcat服务器,自动解压WAR包,此时会在Tomcat的webapps目录下生成一个名为`cas`的文件夹。
4. **访问CAS**:通过浏览器访问`http://localhost:8896/cas`来测试CAS服务是否正常启动。
##### 2.2 配置CAS使用数据库验证为了实现更安全、更灵活的身份验证机制,我们可以配置CAS使用数据库进行用户身份验证。
具体步骤如下:1. **修改部署配置文件**:打开`cas-server-webapp\WEB-INF\deployerConfigContext.xml`文件,找到`SimpleTestUsernamePasswordAuthenticationHandler`配置项,将其替换为`QueryDatabaseAuthenticationHandler`。
```xml <bean id="authenticationHandler" class="org.jasig.cas.authentication.handler.QueryDatabaseAuthenticationHandler"> <!-- 数据库连接数据源 --> <property name="dataSource" ref="dataSource"/> <!-- 查询语句 --> <property name="sql" value="SELECT password FROM users WHERE username = ?"/> <!-- 密码加密方式 --> <property name="passwordEncoder" ref="passwordEncoder"/> </bean> ```2. **配置数据库连接**:在同一文件中添加一个新的`dataSource` bean来定义数据库连接信息。
```xml <bean id="dataSource" class="org.springframework.jdbc.datasource.DriverManagerDataSource"> <property name="driverClassName" value="com.mysql.jdbc.Driver"/> <property name="url" value="jdbc:mysql://localhost:3306/casdb"/> <property name="username" value="casuser"/> <property name="password" value="password"/> </bean> ```3. **配置密码加密方式**:继续在同一文件中添加`passwordEncoder` bean来指定密码加密方式,这里使用MD5作为示例。
```xml <bean id="passwordEncoder" class="org.springframework.security.crypto.password.StandardPasswordEncoder"> <constructor-arg value="MD5"/> </bean> ```4. **测试数据库验证**:重启Tomcat服务器,访问CAS服务器页面,使用数据库中的用户名和密码尝试登录,验证是否可以成功登录。
#### 三、CAS工作原理CAS的工作原理主要分为以下几个步骤:1. **用户访问服务**:用户首次访问受保护的资源时,CAS客户端会检测到HTTP请求中缺少ServiceTicket(简称ST),表明用户尚未经过身份验证。
2. **重定向至CAS服务器**:CAS客户端会将用户重定向到CAS服务器进行身份验证,并携带用户的请求URL作为参数(service参数)。
3. **用户认证**:CAS服务器接收到来自用户的认证请求后,引导用户进入登录页面。
用户输入用户名和密码进行登录,若身份验证成功,则CAS服务器通过HTTPS协议返回一个TGC(Ticket-Granting Cookie)给浏览器。
4. **发放ServiceTicket**:CAS服务器生成一个随机的ServiceTicket(简称ST),并将用户重定向回CAS客户端。
5. **验证ServiceTicket**:CAS客户端收到ST后,向CAS服务器验证ST的有效性。
如果验证通过,则允许用户访问受保护资源。
6. **传输用户信息**:CAS服务器验证ST通过后,将用户的相关认证信息发送给CAS客户端。
通过以上步骤,CAS实现了单点登录的功能,极大地提升了用户体验和系统的安全性。
### 四、CAS与HTTPS在配置CAS服务器时,可以选择使用HTTPS协议来增强通信的安全性。
如果选择HTTPS协议,则需要在服务器上配置CAS证书。
证书的创建和导入过程可以参考以下链接:[http://m.blog..net/zrk1000/article/details/51166603](http://m.blog..net/zrk1000/article/details/51166603)### 总结本文详细介绍了如何配置CAS单点登录服务,并重点讲解了如何利用Java代码实现CAS的配置,包括使用数据库进行登录验证的具体步骤。
同时,还阐述了CAS的基本工作原理,帮助读者更好地理解CAS的工作流程和技术细节。
2025/6/15 19:47:19 293KB
1
自己写的。
哈哈哈哈。
第一个python练手器,使用了python.
2025/6/15 8:57:55 5KB may
1
正则表达式是用于字符串匹配的强大工具,它能够使用一套规则来匹配文本中的字符组合。
在JavaScript中,正则表达式的应用非常广泛,可用于字符串的搜索、替换、提取等操作。
关于正则表达式的基本语法和应用场景:1.字符串长度的计算可以考虑字符的字节大小。
中文字符属于双字节字符,每个字符长度记为2,ASCII字符每个长度计为1。
可以使用正则表达式配合String的扩展方法来实现。
2.匹配中文字符的正则表达式使用Unicode范围来指定,`\u4e00-\u9fa5`包括了绝大多数汉字字符。
3.匹配双字节字符时,可以使用`[^\x00-\xff]`,这可以匹配任何非ASCII字符。
4.匹配空行,可以使用正则表达式`\n[\s|]*\r`,这能够识别连续换行符之间的空白字符。
5.匹配HTML标签通常使用较为复杂的正则表达式,例如`/<(.*)>.*<\/\1>|<(.*)\/>/`,这能够匹配开始标签和自结束标签。
6.去除字符串首尾的空格,可以使用正则表达式`(^\s*)|(\s*$)`,这在JavaScript中通过扩展String原型的方式实现。
7.IP地址的匹配和转换可以通过正则表达式解析IP地址的各部分数字,并将其转换为一个数值,例如`functionIP2V(ip)`,该函数会将IP地址转换为数值形式。
8.正则表达式也可以用于提取URL中的文件名,例如`varip="**.***.**.***"`,之后使用`split`函数处理字符串。
9.去除字符串中重复字符可以使用正则表达式和后向引用的组合,但需要注意到顺序有要求的字符串可能不适用此方法。
10.匹配Email地址和网址URL的正则表达式也是常见的需求,它们通常包含复杂的规则和结构。
11.利用正则表达式限制网页表单中的文本框输入内容,如限制只能输入中文,可以使用`onkeyup`和`onbeforepaste`事件处理函数结合正则表达式。
正则表达式的能力并非无限,它有时可能无法准确匹配某些复杂的字符串模式,尤其是当字符串顺序对结果有影响时,例如在去重字符串中的重复字符时,可能会出现匹配不正确的情况。
在使用正则表达式时,需要注意以下几点:-某些正则表达式操作可以通过非正则表达式的方法简化实现,例如使用`split`函数代替复杂的正则表达式来处理IP地址。
-在应用正则表达式进行匹配时,需要对结果进行验证,尤其是正则表达式自身可能会有匹配不精确的情况。
-在应用正则表达式于生产环境之前,要进行充分的测试,保证其正确性。
通过上述的知识点,可以看出正则表达式在JavaScript编程中发挥着至关重要的作用。
掌握其使用和技巧对于开发人员来说是非常重要的。
无论是在字符串处理、表单验证还是数据提取等场景,合理有效地使用正则表达式可以大大提高编程效率和代码质量。
2025/6/14 23:57:10 74KB
1
浅墨出品,零资源分下载,分享精神至上~运行可以看到两幅图中的SURF特征点检测效果,为稍后将放出的特征点匹配做准备~程序的核心部分为OpenCV中的SurfFeatureDetector类和SurfDescriptorExtractor类。
博文《【OpenCV入门教程之十七】OpenCV重映射&SURF特征点检测合辑》的配套详细注释源代码之一。
博文链接:http://blog.csdn.net/poem_qianmo/article/details/309745131.已将dll打包到Release文件夹下,运行Release文件夹中的exe可以直接看到运行结果.2.源代码运行需要进行OpenCV+VS开发环境的配置。
可以参看我写的配置博文:http://blog.csdn.net/poem_qianmo/article/details/198093373.编写环境:VisualStudio20104.写作当前代码时配套使用的OpenCV版本:2.4.95.推荐代码结合博文一起看,学习效果更佳。
by@浅墨_毛星云
2025/6/14 14:35:17 2.13MB OpenCV SURF C++ 图像处理
1
本文基于改进型粒子群算法的多重阈值图像分割方法研究
1
yolov3Tiny的cfg配置文件以及weights文件,测试帧数达到40+,精度高
2025/6/10 19:19:13 31.34MB ML
1
这次的HCIP-RSRouting&Switching方向的认证课程,主要的技术领域集中在路由和交换技术,当然也包括了更多其它网络技术领域。
而课程的技术内容也是集中在了中小型企业网络与园区网络的规划。
安德讲师为我们全新授课,全新改变升级和更名的HCIP认证,课程内容也是非常丰富,分集的课程数量也超过了100多集,还有相关课程的文档、题库、实验、及考试题库的讲解,适合学习、备考以及进军HCIE前的知识储备├─【07】HCIP(HCNP)数通路由交换必备工具.zip(1)\【001】HCNPHCIP数通路由交换理论;
目录中文件数:110个├─【001】HCIP-OSPF基础知识.avi├─【002】HCIP-OSPF进程和接口基本配置.avi├─【003】HCIP-多区域的OSPF和路由器ID.avi├─【004】HCIP-OSPF报文类型和基本的LSA.avi├─【005】HCIP-OSPF邻居和邻接关系排障.avi├─【006】HCIP-OSPF邻居和邻接关系排障.avi├─【007】HCIP--OSPF邻居排障.avi├─【008】HCIP-OSPF的网络类型1.avi├─【009】HCIP--OSPF邻居状态机.avi├─【010】HCIP-OSPF的LSA详解1.avi├─【011】HCIP-OSPF的LSA详解2.avi├─【012】HCIP-OSPF的域间路由计算.avi├─【013】HCIP-OSPF的外部路由计算.mp4├─【014】HCIP-MA网络的优化.avi├─【015】HCIP-ASBR的汇总和不同进程的重分.avi├─【016】HCIP-特殊区域之末节区域.avi├─【017】HCIP-OSPF特殊区域之NSSA.avi├─【018】HCIP-认识中间系统协议.avi├─【019】HCIP-中间系统网络实体标题和基本配置.avi├─【020】HCIP-中间系统路由器类型.avi├─【021】HCIP-中间系统报文类型和网络类型.avi├─【022】HCIP--中间系统邻居关系建立和电路调整.avi├─【023】HCIP--中间系统邻居关系和3次握手.avi├─【024】HCIP-中间系统知识串讲.avi├─【025】HCIP-中间系统的LSP交互.avi├─【026】HCIP--基本的中间系统路由泄露.avi├─【027】HCIP-中间系统的收敛.avi├─【028】HCIP-BGP的基本特征.avi├─【029】HCIP-建立基本的iBGP和eBGP.avi├─【030】HCIP--BGP通告原则第一部分.avi├─【031】HCIP--BGP的下一跳和通告原则第二部分.avi├─【032】HCIP-BGP通告原则第三部分.avi├─【033】HCIP-BGP自动汇总.avi├─【034】HCIP--BGP的手工聚合.avi├─【035】HCIP--BGP的手工聚合续集.avi├─【036】HCIP--BGP的路由属性.avi├─【037】HCIP--华为设备BGP选路原则1.avi├─【038】HCIP-华为设备BGP选路原则2.avi├─【039】HCIP-华为设备BGP选路原则3.avi├─【040】HCIP-华为设备BGP团体属性1.avi├─【041】HCIP-华为设备BGP团体属性2.avi├─【042】HCIP-华为设备BGP路由反射器.avi├─【043】HCIP-华为设备BGP的联邦.avi├─【044】HCIP-华为设备路由控制基础.avi├─【045】HCIP-华为设备路由控制实验和本质.avi├─【046】HCIP-华为设备通过路由策略解决次优路由.avi├─【047】HCIP-华为设备路由环路实验和方案.avi├─【048】HCIP--前缀列表和实验.avi├─【049】HCIP-华为设备实现route-policy和路由过滤.avi├─【050】HCIP--华为设备路由过滤.avi├─【051】HCIP-华为设备通过修改优先级解决次优路由.avi├─【052】HCIP--华为设备修改AD以及默认路由分析.avi├─【053】HCIP-策略路由.avi├─【054】HCIP-华为MPLS技术基础.avi├─【055】HCIP--华为MPLS技术架构和基本配置.avi├─【056】HCIP-华为设备MPLS回顾和架构.a
2025/6/10 1:05:57 75B HCIP 华为HCIP培训视频
1
作为1-bit压缩感知重构算法,在此基础上可以仿真,改进稀疏度自适应算法
2025/6/9 16:29:29 102KB 1-bitCS重构
1
共 1000 条记录 首页 上一页 下一页 尾页
在日常工作中,钉钉打卡成了我生活中不可或缺的一部分。然而,有时候这个看似简单的任务却给我带来了不少烦恼。 每天早晚,我总是得牢记打开钉钉应用,点击"工作台",再找到"考勤打卡"进行签到。有时候因为工作忙碌,会忘记打卡,导致考勤异常,影响当月的工作评价。而且,由于我使用的是苹果手机,有时候系统更新后,钉钉的某些功能会出现异常,使得打卡变得更加麻烦。 另外,我的家人使用的是安卓手机,他们也经常抱怨钉钉打卡的繁琐。尤其是对于那些不太熟悉手机操作的长辈来说,每次打卡都是一次挑战。他们总是担心自己会操作失误,导致打卡失败。 为了解决这些烦恼,我开始思考是否可以通过编写一个全自动化脚本来实现钉钉打卡。经过一段时间的摸索和学习,我终于成功编写出了一个适用于苹果和安卓系统的钉钉打卡脚本。
2024-04-09 15:03 15KB 钉钉 钉钉打卡