Tutorial

How to Scrape LinkedIn with Rust

Step-by-step guide to scraping LinkedIn search results using Rust and the Scavio API. Get post results, profile results, company results as structured JSON.

LinkedIn contains valuable data — post results, profile results, company results, post snippets, and more. Scraping this data directly means dealing with anti-bot detection, CAPTCHAs, IP rotation, and constantly breaking selectors. The Scavio API handles all of that and returns clean, structured JSON from a single POST request.

This tutorial shows you how to scrape LinkedIn using Rust and the Scavio API. By the end, you will have a working Rust script that fetches real-time LinkedIn data and parses the results.

Prerequisites

  • Rust installed on your machine
  • A Scavio API key (free tier includes 500 credits/month — no credit card required)

Step 1: Install Dependencies

Install reqwest to make HTTP requests:

Bash
cargo add reqwest serde serde_json tokio --features reqwest/json,tokio/full

Step 2: Make Your First LinkedIn Search

Send a POST request to the Scavio LinkedIn API endpoint with your query. The API returns structured JSON with post results, profile results, company results, and more.

use reqwest::Client;
use serde_json::{json, Value};

#[tokio::main]
async fn main() -> Result<(), Box<dyn std::error::Error>> {
    let api_key = "your_scavio_api_key";

    let client = Client::new();
    let response = client
        .post("https://api.scavio.dev/api/v1/search")
        .header("x-api-key", api_key)
        .json(&json!({ "query": query }))
        .send()
        .await?;

    let data: Value = response.json().await?;
    println!("{}", serde_json::to_string_pretty(&data)?);
    Ok(())
}

Step 3: Example Response

The API returns structured JSON. Here is an example response for a LinkedIn search:

JSON
{
  "search_metadata": { "status": "success" },
  "organic_results": [
    {
      "position": 1,
      "title": "Jane Doe - Senior AI Engineer - Acme Corp | LinkedIn",
      "link": "https://www.linkedin.com/in/janedoe",
      "snippet": "San Francisco Bay Area · Senior AI Engineer at Acme Corp · 5,000+ connections · Experienced in LangChain, LangGraph, and RAG..."
    }
  ]
}

Every field is structured and typed — no HTML parsing, no CSS selectors, no regex extraction. Your Rust code can access any field directly.

Step 4: Full Working Example

Here is a complete, runnable Rust script that searches LinkedIn and prints the results:

use reqwest::Client;
use serde_json::{json, Value};
use std::env;

/// Scrape LinkedIn search results using Scavio API.
/// Returns structured JSON with post results, profile results, company results, and more.

async fn search_linkedin(query: &str) -> Result<Value, Box<dyn std::error::Error>> {
    let api_key = env::var("SCAVIO_API_KEY")?;

    let client = Client::new();
    let response = client
        .post("https://api.scavio.dev/api/v1/search")
        .header("x-api-key", &api_key)
        .json(&json!({ "query": query }))
        .send()
        .await?;

    if !response.status().is_success() {
        return Err(format!("Scavio API error: {}", response.status()).into());
    }

    Ok(response.json().await?)
}

#[tokio::main]
async fn main() -> Result<(), Box<dyn std::error::Error>> {
    let results = search_linkedin("site:linkedin.com/in AI engineer San Francisco").await?;
    println!("{}", serde_json::to_string_pretty(&results)?);
    Ok(())
}

Why Use Scavio Instead of Scraping LinkedIn Directly?

  • No proxy management. Direct scraping requires rotating proxies to avoid IP bans. Scavio handles all of this server-side.
  • No CAPTCHA solving. LinkedIn aggressively blocks automated requests. Scavio returns clean data every time.
  • Structured JSON output. No HTML parsing or CSS selector maintenance. Get typed, consistent data from every request.
  • Multi-platform in one API. Search Google, Amazon, YouTube, and Walmart from the same API key with the same authentication pattern.
  • Free tier included. 500 credits/month with no credit card required. Each search costs 1 credit.

Frequently Asked Questions

Scraping publicly available data from LinkedIn is generally legal, but you should review LinkedIn's Terms of Service. Using the Scavio API avoids the legal gray areas of direct scraping since Scavio handles all data collection through proper channels and returns structured results via API.

Direct scraping of LinkedIn requires managing proxies, CAPTCHAs, rate limits, and anti-bot detection. The Scavio API handles all of this for you. Send a POST request with your query and get structured JSON back — no proxy management or browser automation needed.

The Scavio API returns structured JSON with post results, profile results, company results, post snippets, author headlines, company descriptions, employee counts. All data is returned in a clean, consistent format that is easy to parse in Rust.

Scavio offers a free tier with 500 credits per month. Each API request costs 1 credit regardless of which platform you search. No credit card required to start. Paid plans start at $30/month for higher volumes.

Scavio returns LinkedIn results in 1-3 seconds on average. Results are fetched in real time from LinkedIn — there is no caching layer or stale data. Every request returns live results.

Start Scraping LinkedIn with Rust

Get your free Scavio API key and start fetching LinkedIn data in Rust. 500 free credits/month — no credit card required.