Linux下RPM打包流程分享

本文主要和大家分享linux下rpm打包流程,希望能帮助到大家。

开始前的准备

安装rpmbuild软件包

yum -y install rpm-build

生成相关目录

要生成rpm相关目录,可以手动创建,也可以通过rpmbuild命令创建。如:

[root@yang data]# rpmbuild zabbix_agentd_ops.spec error: File /root/rpmbuild/SOURCES/zabbix-3.0.3.tar.gz: No such file or directory有报错,无需理会,可以看到rpmbuild目录已经创建完成[root@yang ~]# tree rpmbuild/rpmbuild/├── BUILD├── BUILDROOT├── RPMS├── SOURCES├── SPECS└── SRPMS

编写SPEC文件

SPEC关键字

Name: 软件包的名称,后面可使用%{name}的方式引用

Summary: 软件包的内容概要

Version: 软件的实际版本号,例如:1.0.1等,后面可使用%{version}引用

Release: 发布序列号,例如:1linuxing等,标明第几次打包,后面可使用%{release}引用

Group: 软件分组,建议使用标准分组

License: 软件授权方式,通常就是GPL

Source: 源代码包,可以带多个用Source1、Source2等源,后面也可以用%{source1}、%{source2}引用

BuildRoot: 这个是安装或编译时使用的“虚拟目录”,考虑到多用户的环境,一般定义为:%{tmppath}/{name}-%{version}-%{release}-root或%{tmppath}/%{name}-%{version}-%{release}-buildroot-%%__id_u} -n}.该参数非常重要,因为在生成rpm的过程中,执行make install时就会把软件安装到上述的路径中,在打包的时候,同样依赖“虚拟目录”为“根目录”进行操作。后面可使用$RPM_BUILD_ROOT 方式引用。

URL: 软件的主页

Vendor: 发行商或打包组织的信息,例如RedFlag Co,Ltd

Disstribution: 发行版标识

Patch: 补丁源码,可使用Patch1、Patch2等标识多个补丁,使用%patch0或%{patch0}引用

Prefix: %{_prefix} 这个主要是为了解决今后安装rpm包时,并不一定把软件安装到rpm中打包的目录的情况。这样,必须在这里定义该标识,并在编写%install脚本的时候引用,才能实现rpm安装时重新指定位置的功能

Prefix: %{sysconfdir} 这个原因和上面的一样,但由于%{prefix}指/usr,而对于其他的文件,例如/etc下的配置文件,则需要用%{_sysconfdir}标识

Build Arch: 指编译的目标处理器架构,noarch标识不指定,但通常都是以/usr/lib/rpm/marcros中的内容为默认值

Requires: 该rpm包所依赖的软件包名称,可以用>=或= 1.0.20 zlib  ※“>=”号两边需用空格隔开,而不同软件名称也用空格分开,还有例如PreReq、Requires(pre)、Requires(post)、Requires(preun)、Requires(postun)、BuildRequires等都是针对不同阶段的依赖指定

Provides: 指明本软件一些特定的功能,以便其他rpm识别

Packager: 打包者的信息

%description 软件的详细说明

SPEC脚本主体

%prep 预处理脚本

%setup -n %{name}-%{version}** 把源码包解压并放好通常是从/usr/src/asianux/SOURCES里的包解压到/usr/src/asianux/BUILD/%{name}-%{version}中。一般用%setup -c就可以了,但有两种情况:一就是同时编译多个源码包,二就是源码的tar包的名称与解压出来的目录不一致,此时,就需要使用-n参数指定一下了。

%patch 打补丁通常补丁都会一起在源码tar.gz包中,或放到SOURCES目录下。一般参数为:

%patch -p1 使用前面定义的Patch补丁进行,-p1是忽略patch的第一层目

%Patch2 -p1 -b xxx.patch 打上指定的补丁,-b是指生成备份文件

补充

%setup 不加任何选项,仅将软件包打开。 

%setup -n newdir 将软件包解压在newdir目录。 

%setup -c 解压缩之前先产生目录。 

Linux+PHP+MySQL案例教程 Linux+PHP+MySQL案例教程

本书以培养高级网站建设与管理人才为目标,内容循序渐进,由浅入深,通过大量的实例系统全面地介绍了Linux+PHP+MySQL环境下的网络后台开发技术。本书详尽分析了近30个典型案例。包括计数器、网站流量统计、留言板、论坛系统、聊天室、投票与调查、用户管理、新闻发布系统、广告轮播、购物系统等等,力求让读者通过对案例的学习,轻松掌握PHP和MySQL的编程精要,迅速掌握网络后台开发技巧。  本书适

Linux+PHP+MySQL案例教程 466 查看详情 Linux+PHP+MySQL案例教程

%setup -b num 将第num个source文件解压缩。 

%setup -T 不使用default的解压缩操作。 

%setup -T -b 0 将第0个源代码文件解压缩。 

%setup -c -n newdir 指定目录名称newdir,并在此目录产生rpm套件。 

%patch 最简单的补丁方式,自动指定patch level。 

%patch 0 使用第0个补丁文件,相当于%patch ?p 0。 

%patch -s 不显示打补丁时的信息。 

%patch -T 将所有打补丁时产生的输出文件删除。

%configure 这个不是关键字,而是rpm定义的标准宏命令。意思是执行源代码的configure配置,在/usr/src/asianux/BUILD/%{name}-%{version}目录中进行 ,使用标准写法,会引用/usr/lib/rpm/marcros中定义的参数。另一种不标准的写法是,可参考源码中的参数自定义,例如:

引用CFLAGS="$RPM_OPT_FLAGS" CXXFLAGS="$RPM_OPT_FLAGS" ./configure --prefix=%{_prefix}

%build 开始构建包,在/usr/src/asianux/BUILD/%{name}-%{version}目录中进行make的工作

%install 开始把软件安装到虚拟的根目录中.在/usr/src/asianux/BUILD/%{name}-%{version}目录中进行make install的操作。这个很重要,因为如果这里的路径不对的话,则下面%file中寻找文件的时候就会失败。 常见内容有:

%makeinstall 这不是关键字,而是rpm定义的标准宏命令。也可以使用非标准写法:make DESTDIR=$RPM_BUILD_ROOT install或引用make prefix=$RPM_BUILD_ROOT install

需要说明的是,这里的%install主要就是为了后面的%file服务的。所以,还可以使用常规的系统命令:引用install -d $RPM_BUILD_ROOT/和cp -a * $RPM_BUILD_ROOT/

%clean        清理临时文件

%pre           rpm安装前执行的脚本

%post        rpm安装后执行的脚本

%preun         rpm卸载前执行的脚本

%postun    rpm卸载后执行的脚本

%files 定义那些文件或目录会放入rpm中

%defattr (-,root,root)** 指定包装文件的属性,分别是(mode,owner,group),-表示默认值,对文本文件是0644,可执行文件是0755

%changelog     变更日志

实例:

%define zabbix_user zabbix                    #自定义宏,名字为zabbix_user值为zabbix,%{zabbix_user}引用Name:    zabbix                                #软件包的名字,后面可用%{name}引用Version:    3.0.3                            #软件的实际版本号,可使用%{version}引用Release:    1%{?dist}                        #发布序列号,标明第几次打包    Summary:    zabbix_agentd                    #软件包内容概要Group:        zabbix                            #软件包分组License:    GPL                                #授权许可方式URL:        www.yang.com                    #软件的主页Source0:    zabbix-3.0.3.tar.gz                #源代码包,可以有Source0,Source1等源BuildRequires:        gcc, gcc-c++            #制作rpm包时,所依赖的基本库Requires:    gcc, gcc-c++, chkconfig            #安装rpm包时,所依赖的软件包%description                                #定义rpm包的描述信息Zabbix agentd 3.0.3%pre                                        #rpm包安装前执行的脚本grep zabbix /etc/passwd > /dev/nullif [ $? != 0 ] then useradd zabbix -M -s /sbin/nologinfi[ -d /etc/zabbix   ]||rm -rf /etc/zabbix*%post                                        #rpm包安装后执行的脚本sed -i "/^ServerActive=/cServerActive=172.30.17.35" /etc/zabbix/etc/zabbix_agentd.confsed -i "/^Server=/cServer=172.30.17.35" /etc/zabbix/etc/zabbix_agentd.confsed -i "/Timeout=3/cTimeout=30" /etc/zabbix/etc/zabbix_agentd.confsed -i "/HostMetadata=/cHostMetadata=PostgreSQL" /etc/zabbix/etc/zabbix_agentd.confsed -i "/^Hostname=/cHostname=PostgreSQL" /etc/zabbix/etc/zabbix_agentd.confecho "UnsafeUserParameters=1" >>/etc/zabbix/etc/zabbix_agentd.confecho "EnableRemoteCommands=1" >>/etc/zabbix/etc/zabbix_agentd.confecho "Include=/etc/zabbix/etc/zabbix_agentd.conf.d/*.conf" >>/etc/zabbix/etc/zabbix_agentd.confchkconfig zabbix_agentd on%preun                                        #rpm卸载前执行的脚本systemctl stop zabbix_agentd%postun                                        #rpm卸载后执行的脚本userdel  zabbixrm -rf /etc/zabbix*%prep                                        #这个宏开始%setup -q                                    #解压并cd到相关目录%build                                        #定义编译软件包时的操作./configure --prefix=/etc/%{name}-%{version}   --enable-agentmake -j16 %{?_smp_mflags}%install                                    #定义安装软件包,使用默认值即可test -L %{buildroot}/etc/%{name} && rm -f %{buildroot}/etc/%{name}install -d %{buildroot}/etc/profile.dinstall -d %{buildroot}/etc/init.dmake install DESTDIR=%{buildroot}echo 'export PATH=/etc/zabbix/bin:/etc/zabbix/sbin:$PATH' > %{buildroot}/etc/profile.d/%{name}.shln -sf /etc/%{name}-%{version}             %{buildroot}/etc/%{name}cp %{_buildrootdir}/postgresql.conf         %{buildroot}/etc/%{name}-%{version}/etc/zabbix_agentd.conf.d/postgresql.confcp %{_buildrootdir}/tcp_connections.sh      %{buildroot}/etc/%{name}-%{version}/etc/zabbix_agentd.conf.d/tcp_connections.shcp %{_buildrootdir}/iostat-collect.sh          %{buildroot}/etc/%{name}-%{version}/etc/zabbix_agentd.conf.d/iostat-collect.sh cp %{_buildrootdir}/iostat-parse.sh          %{buildroot}/etc/%{name}-%{version}/etc/zabbix_agentd.conf.d/iostat-parse.shcp %{_buildrootdir}/iostat-zabbix.conf      %{buildroot}/etc/%{name}-%{version}/etc/zabbix_agentd.conf.d/iostat-zabbix.conf cp %{_buildrootdir}/zabbix_agentd         %{buildroot}/etc/init.d/zabbix_agentd%files                                        #定义rpm包安装时创建的相关目录及文件。在该选项中%defattr (-,root,root)一定要注意。它是指定安装文件的属性,分别是(mode,owner,group),-表示默认值,对文本文件是0644,可执行文件是0755。/etc/%{name}/etc/%{name}-%{version}/*/etc/init.d/zabbix_agentd/etc/profile.d/%{name}.sh%changelog                                    #主要用于软件的变更日志。该选项可有可无%clean rm -rf %{buildroot}                         #清理临时文件

RPM包制作拓展

如果想为zabbix增加启动控制脚本或一些其他的配置文件,可以将其放在SOURCE下,然后复制过去

将启动脚本放在SOURCE目录

      [root@yang ~/rpmbuild/SOURCES]# ll      total 15116      -rwxr-xr-x 1 root root      362 Aug  1 12:03 hostmonitor.conf      -rwxr-xr-x 1 root root      505 Aug  1 12:03 iostat-collect.sh      -rwxr-xr-x 1 root root      953 Aug  1 12:03 iostat-parse.sh      -rw-r--r-- 1 root root      772 Aug  1 12:03 iostat-zabbix.conf      -rwxr-xr-x 1 root root      813 Aug  1 12:03 nginx_monitor.sh      -rw-r--r-- 1 root root    14868 Aug  1 12:03 postgresql.conf      -rw-r--r-- 1 root root       77 Aug  1 12:03 process.discovery      -rw-r--r-- 1 root root      552 Aug  1 12:03 redis_check.conf      -rw-r--r-- 1 root root      356 Aug  1 12:03 redis_cluster_check.py      -rw-r--r-- 1 root root      363 Aug  1 12:03 redis_multiport_check.py      -rwxr-xr-x 1 root root      783 Aug  1 12:03 tcp_connections.sh      -rw-r--r-- 1 root root      852 Aug  1 12:03 userparameter_nginx.conf      -rw-r--r-- 1 root root      172 Aug  1 12:03 userparameter_process.conf      -rw-r--r-- 1 root root 15407273 Jul 20 10:53 zabbix-3.0.3.tar.gz      -rwxr-xr-x 1 root root     2182 Aug  1 12:03 zabbix_agentd

编辑 SPEC文件

Source0下增加如下:

        Source0:        zabbix-3.0.3.tar.gz        Source1:        zabbix_agentd        Source2:        nginx_monitor.sh        Source3:        userparameter_nginx.conf        Source4:        hostmonitor.conf        Source5:        process.discovery        Source6:        userparameter_process.conf        Source7:        redis_check.conf        Source8:        redis_cluster_check.py        Source9:        redis_multiport_check.py        Source10:       tcp_connections.sh        Source11:       iostat-collect.sh        Source12:       iostat-parse.sh        Source13:       iostat-zabbix.conf

安装区域增加如下行:

        make install DESTDIR=%{buildroot}        install -p -D -m 0755 %{SOURCE1}        %{buildroot}/etc/init.d/zabbix_agentd        install -p -D         %{SOURCE2}        %{buildroot}/etc/%{name}-%{version}/etc/zabbix_agentd.conf.d/nginx_monitor.sh        install -p -D         %{SOURCE3}        %{buildroot}/etc/%{name}-%{version}/etc/zabbix_agentd.conf.d/userparameter_nginx.conf        install -p -D         %{SOURCE4}        %{buildroot}/etc/nginx/conf.d/hostmonitor.conf        install -p -D         %{SOURCE5}        %{buildroot}/etc/%{name}-%{version}/etc/zabbix_agentd.conf.d/process.discovery        install -p -D         %{SOURCE6}        %{buildroot}/etc/%{name}-%{version}/etc/zabbix_agentd.conf.d/userparameter_process.conf        install -p -D         %{SOURCE7}        %{buildroot}/etc/%{name}-%{version}/etc/zabbix_agentd.conf.d/redis_check.conf        install -p -D         %{SOURCE8}        %{buildroot}/etc/%{name}-%{version}/etc/zabbix_agentd.conf.d/redis_cluster_check.py        install -p -D         %{SOURCE9}        %{buildroot}/etc/%{name}-%{version}/etc/zabbix_agentd.conf.d/redis_multiport_check.py        install -p -D         %{SOURCE10}       %{buildroot}/etc/%{name}-%{version}/etc/zabbix_agentd.conf.d/tcp_connections.sh        install -p -D         %{SOURCE11}       %{buildroot}/etc/%{name}-%{version}/etc/zabbix_agentd.conf.d/iostat-collect.sh        install -p -D         %{SOURCE12}       %{buildroot}/etc/%{name}-%{version}/etc/zabbix_agentd.conf.d/iostat-parse.sh        install -p -D         %{SOURCE13}       %{buildroot}/etc/%{name}-%{version}/etc/zabbix_agentd.conf.d/iostat-zabbix.conf

%file区域增加如下行:

        %files        %defattr (-,root,root,0755)        /etc/%{name}        /etc/%{name}-%{version}/*        /etc/profile.d/%{name}.sh        /etc/nginx/conf.d/hostmonitor.conf        %attr(0755,root,root) /etc/rc.d/init.d/zabbix_agentd

以下为完整的SPEC文件:

Name:    zabbix    Version:    3.0.3        Release:    1%{?dist}Summary:    zabbix_agentdGroup:        zabbixLicense:    GPLURL:        www.yang.comSource0:    zabbix-3.0.3.tar.gzSource1:    zabbix_agentdSource2:    nginx_monitor.shSource3:    userparameter_nginx.confSource4:    hostmonitor.confSource5:    process.discoverySource6:    userparameter_process.confSource7:    redis_check.confSource8:    redis_cluster_check.pySource9:    redis_multiport_check.pySource10:    tcp_connections.shSource11:    iostat-collect.shSource12:    iostat-parse.shSource13:    iostat-zabbix.confBuildRequires:        gcc, gcc-c++Requires:    gcc, gcc-c++, chkconfig%descriptionZabbix agentd 3.0.3%pregrep zabbix /etc/passwd > /dev/nullif [ $? != 0 ] then useradd zabbix -M -s /sbin/nologinfi[ -d /etc/zabbix   ]||rm -rf /etc/zabbix[ -d /etc/zabbix   ]||rm -rf /etc/zabbix-3.0.3%postsed -i "/^ServerActive=/cServerActive=172.30.17." /etc/zabbix/etc/zabbix_agentd.confsed -i "/^Server=/cServer=172.30.17." /etc/zabbix/etc/zabbix_agentd.confsed -i "/Timeout=3/cTimeout=30" /etc/zabbix/etc/zabbix_agentd.confsed -i "/HostMetadata=/cHostMetadata=OPS-TMP" /etc/zabbix/etc/zabbix_agentd.confsed -i "/^Hostname=/cHostname=OPS-TMP" /etc/zabbix/etc/zabbix_agentd.confecho "UnsafeUserParameters=1" >>/etc/zabbix/etc/zabbix_agentd.confecho "EnableRemoteCommands=1" >>/etc/zabbix/etc/zabbix_agentd.confecho "Include=/etc/zabbix/etc/zabbix_agentd.conf.d/*.conf" >>/etc/zabbix/etc/zabbix_agentd.confchkconfig zabbix_agentd on%preunsystemctl stop zabbix_agentd%postunuserdel  zabbixrm -rf /etc/zabbix*%prep%setup -q%build./configure --prefix=/etc/%{name}-%{version}   --enable-agentmake -j16 %{?_smp_mflags}%installtest -L %{buildroot}/etc/%{name} && rm -f %{buildroot}/etc/%{name}install -d %{buildroot}/etc/profile.dmake install DESTDIR=%{buildroot}install -p -D -m 0755 %{SOURCE1}     %{buildroot}/etc/init.d/zabbix_agentdinstall -p -D         %{SOURCE2}     %{buildroot}/etc/%{name}-%{version}/etc/zabbix_agentd.conf.d/nginx_monitor.shinstall -p -D         %{SOURCE3}     %{buildroot}/etc/%{name}-%{version}/etc/zabbix_agentd.conf.d/userparameter_nginx.confinstall -p -D         %{SOURCE4}     %{buildroot}/etc/nginx/conf.d/hostmonitor.confinstall -p -D         %{SOURCE5}     %{buildroot}/etc/%{name}-%{version}/etc/zabbix_agentd.conf.d/process.discoveryinstall -p -D         %{SOURCE6}     %{buildroot}/etc/%{name}-%{version}/etc/zabbix_agentd.conf.d/userparameter_process.confinstall -p -D         %{SOURCE7}     %{buildroot}/etc/%{name}-%{version}/etc/zabbix_agentd.conf.d/redis_check.confinstall -p -D         %{SOURCE8}     %{buildroot}/etc/%{name}-%{version}/etc/zabbix_agentd.conf.d/redis_cluster_check.pyinstall -p -D         %{SOURCE9}     %{buildroot}/etc/%{name}-%{version}/etc/zabbix_agentd.conf.d/redis_multiport_check.pyinstall -p -D         %{SOURCE10}     %{buildroot}/etc/%{name}-%{version}/etc/zabbix_agentd.conf.d/tcp_connections.shinstall -p -D         %{SOURCE11}    %{buildroot}/etc/%{name}-%{version}/etc/zabbix_agentd.conf.d/iostat-collect.shinstall -p -D         %{SOURCE12}    %{buildroot}/etc/%{name}-%{version}/etc/zabbix_agentd.conf.d/iostat-parse.shinstall -p -D            %{SOURCE13}       %{buildroot}/etc/%{name}-%{version}/etc/zabbix_agentd.conf.d/iostat-zabbix.confecho 'export PATH=/etc/zabbix/bin:/etc/zabbix/sbin:$PATH' > %{buildroot}/etc/profile.d/%{name}.shln -sf /etc/%{name}-%{version}             %{buildroot}/etc/%{name}%files%defattr (-,root,root,0755)/etc/%{name}/etc/%{name}-%{version}/*/etc/profile.d/%{name}.sh/etc/nginx/conf.d/hostmonitor.conf%attr(0755,root,root) /etc/rc.d/init.d/zabbix_agentd%changelog%clean rm -rf %{buildroot}

相关推荐:

RPM 进行安装、卸载及管理的操作实例

Linux命令之rpm安装命令的实例代码详解

关于Linux中安装rpm包时报错的解决办法 详解

以上就是Linux下RPM打包流程分享的详细内容,更多请关注创想鸟其它相关文章!

版权声明:本文内容由互联网用户自发贡献,该文观点仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。
如发现本站有涉嫌抄袭侵权/违法违规的内容, 请发送邮件至 chuangxiangniao@163.com 举报,一经查实,本站将立刻删除。
发布者:程序猿,转转请注明出处:https://www.chuangxiangniao.com/p/753865.html

(0)
打赏 微信扫一扫 微信扫一扫 支付宝扫一扫 支付宝扫一扫
Java中的字符编码有哪些,如何处理不同编码的文件?
上一篇 2025年11月25日 21:54:31
白色座椅贴红色标签引发误读 武汉大学回应:会更注意工作细节
下一篇 2025年11月25日 21:54:38

相关推荐

  • composer require-dev和require有什么不同_Composer Require与Require-Dev区别解析

    require用于声明项目运行必需的依赖,如框架、数据库组件和第三方SDK,这些包会随项目部署到生产环境;2. require-dev用于声明仅在开发和测试阶段需要的工具,如PHPUnit、PHPStan、Faker等,不会默认部署到生产环境;3. 安装时composer install根据环境决定…

    2026年5月10日
    900
  • 开源免费PHP工具 PHP开发效率提升利器

    推荐开源免费PHP开发工具以提升效率:VS Code、Sublime Text轻量高效,PhpStorm专业强大;调试用Xdebug、Kint、Ray;依赖管理选Composer;代码质量工具包括PHPStan、Psalm、PHP_CodeSniffer;数据库管理可用%ignore_a_1%MyA…

    2026年5月10日
    000
  • 怎么在PHP代码中实现图片上传功能_PHP图片上传功能实现与安全处理教程

    首先创建含enctype的HTML表单,再用PHP接收文件,检查目录、移动临时文件,验证类型与大小,生成唯一文件名,并调整php.ini限制以确保上传成功。 如果您尝试在PHP项目中添加图片上传功能,但服务器无法正确接收或保存文件,则可能是由于表单配置、文件处理逻辑或安全限制的问题。以下是实现该功能…

    2026年5月10日
    100
  • 获取日期中的周数:CodeIgniter 教程

    本教程旨在帮助开发者在 CodeIgniter 框架中,从日期字符串中准确提取周数。我们将使用 PHP 内置的 DateTime 类,并提供详细的代码示例和注意事项,确保您能够轻松地在项目中实现此功能。 使用 DateTime 类获取周数 PHP 的 DateTime 类提供了一种便捷的方式来处理日…

    2026年5月10日
    000
  • php常量怎么用_PHP常量(define/const)定义与使用方法

    PHP中可通过define函数和const关键字定义常量,用于存储不可变值。define适用于全局作用域,支持动态名称和条件定义,如define(‘SITE_NAME’, ‘MyWebsite’);const在编译时生效,语法简洁但限制多,只能在类或全…

    2026年5月10日
    000
  • Python命令怎样使用profile分析脚本性能 Python命令性能分析的基础教程

    使用Python的cProfile模块分析脚本性能最直接的方式是通过命令行执行python -m cProfile your_script.py,它会输出每个函数的调用次数、总耗时、累积耗时等关键指标,帮助定位性能瓶颈;为进一步分析,可将结果保存为文件python -m cProfile -o ou…

    2026年5月10日
    000
  • PHP动态生成表单输入与POST数据获取实践指南

    本教程详细阐述了如何在php中根据动态数据源(如数据库值)生成多个表单输入框,并演示了如何通过post方法准确无误地获取这些动态生成的输入值。文章强调了正确的输入框命名策略,避免了常见的命名误区,并提供了完整的代码示例,确保开发者能够高效处理动态表单数据。 动态生成表单输入 在Web开发中,我们经常…

    2026年5月10日
    000
  • c++如何实现UDP通信_c++基于UDP的网络通信示例

    UDP通信基于套接字实现,适用于实时性要求高的场景。1. 流程包括创建套接字、绑定地址(接收方)、发送(sendto)与接收(recvfrom)数据、关闭套接字;2. 服务端监听指定端口,接收客户端消息并回传;3. 客户端发送消息至服务端并接收响应;4. 跨平台需处理Winsock初始化与库链接,编…

    2026年5月10日
    000
  • 谷歌浏览器如何截图 谷歌浏览器页面截图技巧

    谷歌浏览器如何截图 谷歌浏览器页面截图技巧谷歌浏览器如何截图 谷歌浏览器页面截图技巧谷歌浏览器如何截图 谷歌浏览器页面截图技巧谷歌浏览器如何截图 谷歌浏览器页面截图技巧

    使用谷歌浏览器的开发者工具截图步骤:1. 按ctrl+shift+i(windows/linux)或cmd+option+i(mac)打开开发者工具。2. 点击右上角三个点,选择”更多工具”,再选择”截图”。3. 选择截取整个页面。推荐的谷歌浏览器扩展…

    2026年5月10日 用户投稿
    100
  • JavaScript函数中插入加载动画(Spinner)的正确方法

    本文旨在解决在JavaScript函数中插入加载动画(Spinner)时遇到的异步问题。通过引入async/await和Promise.all,确保在数据处理完成前后正确显示和隐藏加载动画,提升用户体验。我们将提供两种实现方案,并详细解释其原理和优势。 在Web开发中,当执行耗时操作时,显示加载动画…

    2026年5月10日
    000
  • MySQL数据库不支持中文的解决办法

    接上一篇文章,在解决了mysql+flask环境配置问题之后,往数据库存中文字符串会报1366错误,提示不正确的字符。继而发现默认的mysql采用了latin1字符集,这种编码是不支持中文的。 如果想支持中文的话,需要设置一下mysql字符集。 众所周知utf-8是可以的,gbk也没问题,为了可扩展…

    用户投稿 2026年5月10日
    000
  • PHP多维数组到复杂XML结构的SOAP序列化实践

    本文旨在解决php多维数组向复杂soap xml结构序列化时遇到的“无法序列化结果”问题。通过深入理解soap xml的结构要求,包括命名空间和类型属性,文章将指导您如何构建符合特定xml schema的php关联数组。我们将利用`spatie/array-to-xml`库,详细演示其安装与使用方法…

    2026年5月10日
    000
  • 使用 Ajax 和 FormData 实现文件上传及文本数据提交的完整教程

    本文旨在解决在使用 Ajax 和 FormData 进行文件上传时,遇到的 $_POST 和 $_FILES 为空的问题。通过详细的代码示例和解释,我们将展示如何正确地构建 FormData 对象,并通过 Ajax 将文件和文本数据发送到服务器端,同时避免常见的错误配置,确保数据能够成功地被 PHP…

    2026年5月10日
    000
  • pycharm解析器怎么添加 解析器添加详细流程

    在pycharm中添加解析器的步骤包括:1) 打开pycharm并进入设置,2) 选择project interpreter,3) 点击齿轮图标并选择add,4) 选择解析器类型并配置路径,5) 点击ok完成添加。添加解析器后,选择合适的类型和版本,配置环境变量,并利用解析器的功能提高开发效率。 在…

    2026年5月10日
    000
  • 虫虫漫画直接进入官网入口_虫虫漫画网页版清爽版

    虫虫漫画直接进入官网入口_虫虫漫画网页版清爽版虫虫漫画直接进入官网入口_虫虫漫画网页版清爽版虫虫漫画直接进入官网入口_虫虫漫画网页版清爽版虫虫漫画直接进入官网入口_虫虫漫画网页版清爽版

    虫虫漫画官网入口为www.ccmh.com,用户可直接通过浏览器访问,支持多端适配与账号同步功能,界面简洁无广告,提供海量国漫、日漫、韩漫资源,涵盖恋爱、玄幻等热门题材,更新及时,支持多种阅读模式及离线缓存,阅读体验流畅。 虫虫漫画直接进入官网入口在哪里?这是不少网友都关注的,接下来由PHP小编为大…

    2026年5月10日 用户投稿
    000
  • 从 JavaScript 获取 URL 并在 PHP DataGrid 中使用

    本文档旨在指导开发者如何从 JavaScript 函数中获取 URL,并将其动态应用于 PHP DataGrid。通过前端 JavaScript 动态生成 API 地址,并将其传递给后端的 PHP DataGrid,实现数据根据用户会话动态加载。 动态配置 DataGrid 的 URL 在构建动态 …

    2026年5月10日
    000
  • CodeIgniter在IIS环境下实现URL重写与index.php移除指南

    本教程详细指导如何在IIS服务器上部署的CodeIgniter应用中,移除URL中不必要的index.php。核心解决方案涉及修改CodeIgniter的config.php文件,将$config[‘index_page’]设置为空,并辅以正确的IIS web.config重…

    2026年5月10日
    100
  • PHP安全文件下载:防止直链与保护资源

    本文旨在解决通过检查元素获取直链下载文件的问题,并提供一种安全的PHP服务器端文件交付方案。核心思想是利用PHP作为文件代理,通过设置HTTP响应头直接将文件发送给用户,从而隐藏文件的实际存储路径,有效防止未经授权的直接链接访问。 客户端下载链接的风险与局限性 在构建下载页面时,开发者常常面临一个挑…

    2026年5月10日
    100
  • JavaScript Electron桌面应用

    答案:使用JavaScript开发%ignore_a_1%桌面应用需结合Web技术与Node.js,通过主进程管理窗口、渲染进程展示界面,并利用IPC通信,调用系统功能如文件对话框,最后用electron-builder打包发布,注意安全与进程职责分离。 用JavaScript开发Electron桌…

    2026年5月10日
    000
  • Go语言连接外部MySQL数据库:DSN配置与常见错误解析

    本文详细阐述了go语言使用`go-sql-driver/mysql`驱动连接外部mysql数据库的正确方法。重点介绍了数据源名称(dsn)的规范格式,特别是主机地址部分的配置,以避免常见的“getaddrinfow: the specified class was not found.”等网络解析错…

    2026年5月10日
    000

发表回复

登录后才能评论
关注微信