使用Ubuntu 通过有线共享无线网络给 Windows,可以按照以下步骤操作:


方法 1:使用 Ubuntu 内置网络共享(界面)

1. 确保 Ubuntu 已连接 Wi-Fi
  • 点击右上角网络图标,确保已连接到可用的 Wi-Fi 网络。
2. 用网线连接 Ubuntu 和 Windows
  • 使用以太网线将 Ubuntu 主机和 Windows 电脑连接起来。
3. 在 Ubuntu 上启用网络共享
  • 打开 “设置”(Settings)→ “网络”(Network)。
  • 选择左侧的 “有线”(Wired)连接,点击齿轮图标(⚙️)。
  • IPv4 设置 选项卡中,选择 “共享给其他计算机”(Shared to other computers)。
  • 点击 “应用”(Apply)保存设置。
4. 检查 Ubuntu 有线接口 IP*
  • 打开终端,运行:
    ip addr show
    
    有线接口(如 enp0s25eth0)的 IP 应为 10.42.0.1(Ubuntu 会自动分配)。
5. 在 Windows 上配置网络
  • 确保 Windows 使用 DHCP(自动获取 IP)

    • 打开 “控制面板”“网络和共享中心”“更改适配器设置”
    • 右键点击 以太网“属性” → 双击 “Internet 协议版本 4 (TCP/IPv4)”
    • 选择 “自动获取 IP 地址”“自动获取 DNS 服务器地址”
    • 点击 “确定” 保存。
  • 手动设置(可选,如果 DHCP 不生效)

    • IP 地址:10.42.0.2
    • 子网掩码:255.255.255.0
    • 默认网关:10.42.0.1
    • DNS:8.8.8.8(或 Ubuntu 的 IP 10.42.0.1
6. 测试网络连接
  • 在 Windows 上打开命令提示符(cmd),运行:
    ping 8.8.8.8
    
    如果成功,说明网络共享已生效。

方法 2:手动配置 IP 转发(配置命令行配置)

如果方法 1 不生效,可以手动设置 NAT 转发:

1. 在 Ubuntu 上启用 IP 转发
  • 编辑 /etc/sysctl.conf
    sudo nano /etc/sysctl.conf
    
  • 取消注释或添加:
    net.ipv4.ip_forward=1
    
  • 应用更改:
    sudo sysctl -p
    
2. 设置 NAT 规则
查看NAT规则
sudo iptables -t nat -L -v
  • 假设:

    • 无线接口(Wi-Fi):wlp3s0(用 ip a 查看)
    • 有线接口(以太网):enp0s25(用 ip a 查看)
  • 运行以下命令:

    sudo iptables -t nat -A POSTROUTING -o wlp3s0 -j MASQUERADE
    sudo iptables -A FORWARD -i enp0s25 -o wlp3s0 -j ACCEPT
    sudo iptables -A FORWARD -i wlp3s0 -o enp0s25 -m state --state RELATED,ESTABLISHED -j ACCEPT
    

以下是三条iptables命令的详细解释:

  1. NAT地址伪装(MASQUERADE)
sudo iptables -t nat -A POSTROUTING -o wlp3s0 -j MASQUERADE
  • 作用:将来自有线网卡enp0s25的流量通过无线网卡wlp3s0发出时,自动修改源IP为无线网卡的IP地址
  • 关键点
    • -t nat:操作NAT表
    • POSTROUTING:在数据包发出前的最后处理阶段
    • -o wlp3s0:指定出口网卡
    • MASQUERADE:动态IP伪装(适用于DHCP获取IP的情况)
  1. 正向流量放行规则
sudo iptables -A FORWARD -i enp0s25 -o wlp3s0 -j ACCEPT
  • 作用:允许从有线网卡(enp0s25)进入,从无线网卡(wlp3s0)转发的流量
  • 流向客户端 → 有线网卡 → 无线网卡 → 互联网
  1. 反向流量控制规则
sudo iptables -A FORWARD -i wlp3s0 -o enp0s25 -m state --state RELATED,ESTABLISHED -j ACCEPT
  • 作用:仅允许与已有连接相关的返回流量通过
  • 保护机制
    • -m state:启用连接状态检测
    • RELATED,ESTABLISHED:只放行已建立的连接或关联的新连接(如FTP数据传输)
    • 阻止外部主动发起的连接请求,增强安全性

整体网络流
客户端请求 → enp0s25 → (NAT转换) → wlp3s0 → 互联网
互联网响应 → wlp3s0 → (状态检测) → enp0s25 → 客户端


3. 配置有线接口 IP
  • 将有线接口设为静态 IP:
    sudo ip addr add 10.42.0.1/24 dev enp0s25
    
4. 在 Windows 上手动设置 IP
  • 按照 方法 1 的步骤 5 手动设置 Windows 的 IP 为 10.42.0.2,网关为 10.42.0.1

共享ip段修改

你想修改Ubuntu通过“共享给有线”功能(很可能是指将Wi-Fi网络通过有线网卡共享)后,分配给有线网卡的IP地址(默认通常是10.42.x.x网段)。由于网络共享功能由NetworkManager管理,直接修改配置文件可能不持久,这里给你介绍两种主要的方法。

方法一:通过NetworkManager连接编辑器修改(推荐)

这是最直接且不容易出错的方法。

  1. 打开连接编辑器
    在终端中执行以下命令:

    nm-connection-editor
    
  2. 定位并编辑共享连接
    在弹出的窗口中,找到类型为“以太网”且名称与你共享相关的连接(名称可能非“有线连接1”)。选中它,然后点击右下角的 齿轮图标 或直接双击进行编辑。

  3. 修改IPv4设置

    • 在弹出窗口中,切换到 “IPv4设置” 选项卡。
    • 方法 确保为 “共享至其他用户” 或其他类似共享选项。
    • 现在,你就可以修改 “地址” 字段了。例如,如果你想将IP地址设置为 10.42.0.1,子网掩码通常设置为 255.255.255.0,那么就填写 10.42.0.1/24
    • 修改后,点击 “保存”
  4. 重新激活连接
    保存后,可能需要重启一下该网络连接(先断开再连接)或重启NetworkManager服务sudo systemctl restart NetworkManager),新的IP地址才会生效。

方法二:使用Netplan配置(适用于Ubuntu 17.10及更高版本)

对于较新的Ubuntu版本,Netplan是默认的网络配置工具。如果共享连接创建后生成了Netplan配置,或者你希望有更底层的控制,可以尝试此方法。

  1. 查找Netplan配置文件
    Netplan配置文件通常位于 /etc/netplan/ 目录下,后缀为 .yaml。你可以使用 sudo netplan try 来测试配置是否正确,或者直接使用 sudo netplan apply 来应用配置。

  2. 修改配置文件
    你需要编辑对应的YAML文件。针对一个有静态IP的有线连接,配置结构可能类似如下(注意,共享模式下的具体配置参数可能有所不同,你需要找到对应的连接配置进行修改):

    network:
      version: 2
      renderer: NetworkManager
      ethernets:
        enp0s31f6: # 这里需要替换为你的实际有线网卡接口名
          addresses:
            - 10.42.0.1/24 # 修改为你想要的IP和子网掩码
          # 对于共享连接,网关和DNS可能由共享服务自动处理,此处可能无需设置或设置特殊值
    

    修改后,保存文件。

  3. 应用配置
    在终端中执行:

    sudo netplan apply
    

    如果应用失败或配置有误,可以使用 sudo netplan --debug apply 查看详细错误信息。

常见问题解决

1. Windows 无法上网
  • 检查 Ubuntu 的防火墙是否允许转发:
    sudo ufw allow in on enp0s25
    
  • 确保 Windows 的网关和 DNS 设置正确。

如果windwos 已获取了10.42.0.x的IP,但是不能访问互联网,则需要手动写NAT规则。

  • 假设:

    • 无线接口(Wi-Fi):wlp3s0(用 ip a 查看)
    • 有线接口(以太网):enp0s25(用 ip a 查看)
  • 运行以下命令:

     sudo iptables -t nat -A POSTROUTING -o wlo1 -j MASQUERADE
     sudo iptables -A FORWARD -i enp4s0 -o wlo1 -j ACCEPT
     sudo iptables -A FORWARD -i wlo1 -o enp4s0 -m state --state RELATED,ESTABLISHED -j ACCEPT
    

2. 接口名称不同
  • ip aifconfig 确认你的实际接口名(如 eth0enp0s3 等)。
3. NAT 规则重启失效
  • 若要持久化 iptables 规则,安装 iptables-persistent
    sudo apt install iptables-persistent
    sudo netfilter-persistent save
    

  • 推荐方法 1(图形化设置),简单快捷,NAT规则。
  • 如果无效,再尝试 方法 2(手动配置 NAT)。
  • 确保 Windows 使用 自动获取 IP 或手动设置正确的网关(10.42.0.1)。

重启net 服务

sudo systemctl restart NetworkManager.service
Logo

魔乐社区(Modelers.cn) 是一个中立、公益的人工智能社区,提供人工智能工具、模型、数据的托管、展示与应用协同服务,为人工智能开发及爱好者搭建开放的学习交流平台。社区通过理事会方式运作,由全产业链共同建设、共同运营、共同享有,推动国产AI生态繁荣发展。

更多推荐