well , a simple solution would be to cascade 2 routers , on main 1 the server will exist , but in the second , the rest of laptops/desktops.
In this way , can assign 2 subnets , second subnet will be able to access main server , but not backwards.
The hard way is to use vlan(s) but the price will raise up !
|