简介 本人远程服务器上面除了搭建博客之外,还搭建了Gitea私人代码仓库和图床服务,但是两个服务上面都没有自带 sitemap.xml,不方便搜索引擎收录对应的链接。...于是乎自己写了个脚本用来自动生成 sitemap.xml 使用 项目地址:https://git.zeekling.cn/python/sitemap 安装依赖 pip3 install -r requirement.txt...https://git.zeekling.cn/', 'https://git.zeekling.cn/zeekling' ] # 抓取的最大栈深度,默认为2,如果网站比较大的话不建议设置太大,可以在url_mine_list...'/user/forgot_password' ] 修改sitemap.xml位置,sitemap.py # 第一个参数为sitemap.xml的位置 create_xml('sitemap.xml.../sitemap.py 执行完成之后就会生成 sitemap.xml 当然为了更新的快一点可以加入到定时任务里面: 0 */6 * * * cd /root/git-sitemap && .
在上一篇的文章 Angular 中使用 Api 代理,我们处理了本地联调接口的问题,使用了代理。 我们的接口是单独编写的处理的,在实际的开发项目中,有众多的接口,有些需要登陆凭证,有些不需要。...在使用 angular-cli 生成项目的时候,它已经自动做好了环境的区分,在 app/enviroments 目录下: environments...,他指向你要请求的地址。...当然,你这里添加的内容要配合你代理上加的内容调整,读者可以自己思考验证 添加拦截器 我们生成服务 http-interceptor.service.ts 拦截器服务,我们希望每个请求,都经过这个服务..., HttpInterceptor, // 拦截器 HttpRequest, // 请求 } from '@angular/common/http'; import { Observable
在Angular应用中,RxJS的高效运用主要体现在:异步操作处理RxJS的核心优势在于处理异步操作,如HTTP请求、定时任务、事件监听等。...在Angular中,你可以使用HttpClient模块配合RxJS的Observable来发起HTTP请求,这使得请求和响应的管理变得简洁且易于理解。...这对于复杂应用中的状态同步非常有用。...,甚至可以结合retry操作符实现请求重试。...的响应式表单中,RxJS可以帮助你处理表单输入的验证、值的变化监听等,使得表单逻辑更加清晰。
为了更好的利于SEO,加快百度、360、谷歌、bing、搜狗等收录,我们需要网站生成sitemap.xml,有些搜索引擎只支持.xml,不支持.txt,所以我们必须在511遇见论坛下自动生成sitemap.xml...,由于我们采用了伪静态,所以生成的链接必须和伪静态规则一致,在discuz后台插件搜索了几个,姑且不谈收费免费,发现很不稳定,且静态规则无法兼容,这里我们采用discuz的定时任务,自动生成sitemap.xml...defined('IN_DISCUZ')) {exit('Access Denied');}$filename='sitemap.xml';//以下五项根据具体情况修改即可$cfg_updateperi...*********************************************************************************************///网站地图sitemap.xml
创建包含组件 在 angular 中, 所谓的包含就是在定义固定视图模板的同时, 通过 标签来定义一个可以放动态内容的位置。 下面就来实现一个简单的卡片组件。...: import { NgModule } from '@angular/core'; import { BrowserModule } from '@angular/platform-browser...来生成这个组件的话, 会自动在 AppModule 中添加声明。...使用卡片组件 在另外一个组件 AppComponent 中使用刚刚创建的卡片组件的话, 代码如下所示: <!...包含多个位置 使用 select 属性, 可以在一个组件中定义多个包含位置。 现在继续修改卡片组件, 允许页眉和页脚包含动态内容。 <!
例子 import { Component, OnInit } from '@angular/core'; import { FormBuilder, FormGroup, Validators, FormControl..., AbstractControl } from '@angular/forms'; import { concat, merge, zip, combineLatest, race } from 'rxjs...比如这里在结果里追加上次更新时间,字段名为lastTime this.form.valueChanges .pipe( filter(() => this.form.valid
几个收藏的根据数据库生成Insert语句的存储过程[修正版] -- ====================================================== --根据表中数据生成insert...tablename --print @sql exec (@sql) end -- ====================================================== --根据表中数据生成...' from '+@tablename --print @sqlstr exec( @sqlstr) set nocount off end 原文:几个收藏的根据数据库生成...Insert语句的存储过程 修正了表中的字段如果是SQL中的关键字(如Order)时,生成的脚本执行会出错的bug
关于android中的代码覆盖率,可以参考我前几篇文章: Android手工测试代码覆盖率增强版 Android手工测试的代码覆盖率 Android UI自动化测试的代码覆盖率 官方生成代码覆盖率报告的流程...那么这个coverage.ec在测试完成时会在android系统的/data/data/com.wuba.wuxian.android_0504/目录下生成),然后pull到本地的项目根目录的build.../outputs/code-coverage/connected 目录下,这个时候执行createDebugCoverageReport 根据这个coverage.ec和build/intermediates...根据coverage.ec生成报告 我们在前一篇文章中得到了手工测试的代码覆盖率文件coverage.ec,现在我们根据这个文件如何生成代码覆盖率的报告呢?...很简单,首先我们将这个文件存放到build/outputs/code-coverage/connected下,然后在build.gradle加入如下语句: apply plugin: 'jacoco'
在使用excel的过程中,我们知道,根据一个坐标我们很容易直接找到当前坐标的值,但是如果知道一个坐标里的值,反过来求该点的坐标的话,据我所知,excel没有提供现成的函数供使用,所以需要自己用VBA编写函数使用...(代码来自互联网) 在Excel中,ALT+F11打开VBA编辑环境,在左边的“工程”处添加一个模块 把下列代码复制进去,然后关闭编辑器 Public Function iSeek(iRng As Range...iSeek了,从以上的代码可以看出,iSeek函数带三个参数,其中第一个和第二个参数制定搜索的范围,第三个参数指定搜索的内容,例如 iSeek(A1:P200,20),即可在A1与P200围成的二维数据表中搜索值
本操作方法将逐步指导您生成证书签名请求(CSR)。 这些过程已在Windows 10的IIS 10上进行了测试,但也将在IIS 7.x和8.x中运行。启动IIS管理器。...在中选择服务器 连接 窗格,在窗口的左侧。打开服务器证书双击 服务器证书 图标,位于 IIS的 在窗口的中央窗格中。点击“创建证书申请”点击 创建证书申请… 链接,在 行动 窗口右侧的窗格。...,在上面会有一个分隔符,分别为:-----BEGIN NEW CERTIFICATE REQUEST----------END NEW CERTIFICATE REQUEST-----这个分隔符表示的请求证书内容的开始和结尾...通常所有我们通过程序生成的数据,都尽量避免手工修改,使用记事本最多也就是赋值粘贴下。不同的服务商要求的分隔符也不一样,我们就有遇到有要求下面这样的。...-----BEGIN CERTIFICATE REQUEST----------END CERTIFICATE REQUEST----- 在签名的时候根据提示在记事本中修改就好。
需求 需要根据用户的真实IP限制访问, 但是NGINX前边还有个F5, 导致deny指令不生效. 阻止用户的真实IP不是192.168.14.*和192.168.15.*的访问请求....{ return 403; } 说明如下: proxy_set_header X-Forwarded-For $proxy_add_x_forwarded_for; 获取请求头...X-Forwarded-For中的用户真实IP, 并附加到$proxy_add_x_forwarded_for变量 if...allow 192.168.14.0/24; allow 192.168.15.0/24; deny all; 根据nginx官方文档, deny指令是根据" client address"进行限制的...解释如下: 关于$remote_addr: 是nginx与客户端进行TCP连接过程中,获得的客户端真实地址.
需求 需要根据用户的真实 IP 进行限制, 但是 NGINX 前边还有个 F5, 导致 deny 指令不生效.....* 的访问请求....]") { return 403; } 说明如下: •proxy_set_header X-Forwarded-For proxy_add_x_forwarded_for; 获取请求头...X-Forwarded-For 中的用户真实 IP, 并附加到 proxy_add_x_forwarded_for 变量 •if... •(...)...allow 192.168.14.0/24; allow 192.168.15.0/24; deny all; 根据nginx官方文档, deny 指令是根据「client address」进行限制的.
转载请声明出处哦~,本篇文章发布于luozhiyun的博客:https://www.luozhiyun.com/archives/677 我们平时在开发中肯定避不开的一个问题是如何在不可靠的网络服务中实现可靠的网络通信...通过不同的错误码来识别不同的错误,在HTTP中status code可以用来识别不同类型的错误; 重试决策。...使用 net/http 重试所带来的问题 重试这个操作其实对于 Go 来说其实还不能直接加一个 for 循环根据次数来进行,对于 Get 请求重试的时候没有请求体,可以直接进行重试,但是对于 Post...在上面这个例子中,在客户端设值了 10ms 的超时时间。在服务端模拟请求处理超时情况,先sleep 20ms,然后再读请求数据,这样必然会超时。...使用对冲的时候需要注意一点是,因为下游服务可能会做负载均衡策略,所以要求请求的下游服务一般是要求幂等的,能够在多次并发请求中是安全的,并且是符合预期的。
我在自己的Ionic 2项目中,使用卡片列出数据: 卡片中有一个导航按钮,根据每项的数据生成连接打开百度地图,我是这样绑定的...console.log(url); return this.sanitizer.bypassSecurityTrustResourceUrl(url); } 我查看console,发现一直在输出...console一直在输出 原来这是Angular2在change detection cycle中不停的调用绑定的方法nav(item)。
小编为大家简单介绍几个Angular15的新特性(以下特性源于Angular官网): 独立API脱离开发者预览版 在Angular14版本的更新中使用了独立的API,使得开发者能够在不使用 NgModules...在Angular15中将这些API已经更新成为了稳定版,并且以后将通过语义版本去控制独立 APIs 的发展。...语言服务中的自动导入 在Angular15中,可以自动导入在模板中使用但是没有添加到NgModule中的组 件或独立组件。 既然Angular都升级了,咱们是不是可以尝试一些新的玩法?...Angular15中引入报表插件 大家都知道Excel作为一款统计、分析数据信息的办公软件,在大家日常工作和生活中起到了非常重要的作用。...下面将介绍如何在Angular15中集成Excel报表插件并实现简单的文件上传和下载。 在本教程中,我们将使用node.js,请确保已安装最新版本。
ERROR in Cannot use 'in' operator to search for 'providers' in null 出现这个问题的原因是,在使用懒加载的时候,没有指定module,
前面已经说过可以通过中间件来处理OPTIONS请求,近日寻得一个简单的办法。 在路由文件中定义一个路由,通过正则来匹配相应的路由。...以上这篇解决在Laravel 中处理OPTIONS请求的问题就是小编分享给大家的全部内容了,希望能给大家一个参考。
在本教程中,我们将学习如何使用 JS 进行AJAX调用。 1.AJAX 术语AJAX 表示 异步的 JavaScript 和 XML。 AJAX 在 JS 中用于发出异步网络请求来获取资源。...来自服务器的响应存储在responseText变量中,该变量使用JSON.parse()转换为JavaScript 对象。...如果存在网络错误,则将拒绝,这会在.catch()块中处理。 如果来自服务器的响应带有任何状态码(如200、404、500),则promise将被解析。响应对象可以在.then()块中处理。...catch block: SyntaxError: Unexpected token I in JSON at position 4 我们看到,即使API抛出500错误,它仍然会首先进入then()块,在该块中它无法解析错误...将响应代码(例如404、500)视为可以在catch()块中处理的错误,因此我们无需显式处理这些错误。
微信公众号:冯文议(ID:fwy-world) HTTP请求,在日常开发中,还是比较常见的,今天给大家分享HttpUtils如何使用。...阅读本文,你将收获: 简单总结HTTP请求常用配置; JavaLib中HttpUtils如何使用; 如何封装HTTP请求工具类。...第一部分:简单总结HTTP请求常用配置 大家好,在 Java 开发中,经常遇到需要调用第三方提供的接口服务,常见的形式是 HTTP + JSON,下面,就对 http 请求常见的设置,做一个说明 http...提供多种请求方式,以满足我们日常需要,先按请求方式来做说明: GET POST PUT PATCH DELETE 在 RESTful API 开发中,我们可以根据这些请求方式设计我们的API接口。...我是小冯,一名Java程序员,专注于程序设计和开发,如果你在开发上遇到问题,欢迎一起交流。
f.write(kmldoc) print "[+]Created googleearthPrint.kml successfully" if name == 'main': main() 把生成的
领取专属 10元无门槛券
手把手带您无忧上云